PHP ORMs: Doctrine vs. Propel

56,141

Solution 1

I'd go with Doctrine. It seems to me that it is a much more active project and being the default ORM for symfony it is better supported (even though officially the ORMs are considered equal).

Furthermore I better like the way you work with queries (DQL instead of Criteria):

<?php
// Propel
$c = new Criteria();
$c->add(ExamplePeer::ID, 20);
$items = ExamplePeer::doSelectJoinFoobar($c);

// Doctrine
$items = Doctrine_Query::create()
       ->from('Example e')
       ->leftJoin('e.Foobar')
       ->where('e.id = ?', 20)
       ->execute();
?>

(Doctrine's implementation is much more intuitive to me).

Also, I really prefer the way you manage relations in Doctrine.

I think this page from the Doctrine documentation is worth a read: http://www.doctrine-project.org/documentation/manual/1_2/en/introduction:doctrine-explained

To sum up: If I were starting a new project or had to choose between learning Doctrine and Propel I'd go for Doctrine any day.

Solution 2

I am biased, since I help a little bit on the next release of Propel, but you must consider that Propel was indeed the first ORM available, then lagged a bit when Doctrine got created, but now has active development again. Symfony 1.3/1.4 comes with Propel 1.4, where most comparisons stop at Propel 1.3. Also, the next release of Propel (1.5) will contain a lot of improvements, especially in the creation of you Criteria (resulting in less code for you to write).

I like Propel because it seems to be less complex than Doctrine: most code is in the few generated classes, whereas Doctrine has split up the functionality in lots of classes. I like to have a good understanding of the libraries I am using (not too much "magic"), but of course, I have more experience with Propel, so maybe Doctrine is not so complicated behind the scenes. Some say Propel is faster, but you should check this for yourself, and consider whether this outweighs other differences.

Maybe you should also consider the availability of Symfony plugins for the different frameworks. I believe Propel has an advantage here, but I don't know how many of the listed plugins are still up-to-date with the latest version of Symfony.

Solution 3

It comes down to personal preference. I use Propel because (among other things) I like the fact that everything has its own concrete getter & setter method. In Doctrine, this is not the case.

Propel:

$person->setName('Derek');
echo $person->getName();

Doctrine:

$person->name = 'Derek';
echo $person->name;

The reason I like having getters & setters is that I can put all kinds of logic in them, if I need to. But that's just my personal preference.

I should also add that although Propel was slow-moving in the past, it is now under active development again. It has released several new versions in the past few months. The most recent version of Propel includes a "fluent query interface" similar to Doctrine's, so you don't have to use Criteria anymore if you don't want to.

Solution 4

It should be noted Doctrine 2 is currently in development released [ed] and functions almost completely different from the current stable version of Doctrine 1. It relies on the Data Mapper pattern instead of Active Record, and uses an 'entity manager' to handle persistence logic. When released it will bear closer resemblance to Java's Hibernate (Doctrine 1 is more like Rails' ActiveRecord).

I've been developing with the alpha release of Doctrine 2, and must say it is heads and shoulders above Doctrine 1 (just my opinion, and I've never used Propel). Chances are good that the Doctrine community will move toward it when it's released.

I would encourage you to check out Doctrine, but if you prefer the Active Record style that Propel and Doctrine use now, you might want to just stick with Propel.

Solution 5

The two references are somewhat outdated so you nevertheless cover some generalities, basically you'd have to evaluate your experience with the framework as such, a major drawback to doctrine is the inability to have an IDE that lets you auto-code in that propel is a winner, learning curves propel and doctrine are very different, it is easier to propel, if your project will need to manage complex data model uses doctrine, if you want to work quickly with an ORM which is best documented and find more support in Propel Internet uses, is much more mature and I believe that most used.

http://propel.posterous.com/propel-141-is-out

Share:
56,141
Tom
Author by

Tom

I'm just here to look at the pictures.

Updated on August 06, 2020

Comments

  • Tom
    Tom almost 4 years

    I'm starting a new project with symfony which is readily integrated with Doctrine and Propel, but I of course need to make a choice.... I was wondering if more experienced people out there have general pros and/or cons for going with either of these two?

    Thanks a lot.

    EDIT: Thanks for the all the responses, useful stuff. There's no truly correct answer to this question so I'll just mark as approved the one that got the most popular up-votes.

  • phidah
    phidah over 14 years
    In the symfony world it seems that Doctrine is definately the most used - especially for newer projects. There are of course a lot of sf 1.0 projects that still use Propel because Doctrine wasn't available for symfony until 1.1.
  • Tom
    Tom over 14 years
    The new query improvements in Propel 1.5 are really nice indeed.
  • Jan Fabry
    Jan Fabry over 14 years
    In Propel 1.5, this query can also be written as Example_Query::create()->joinWith('FooBar')->filterId(20)->f‌​ind() (or findPK(20) after the joinWith if Id is your primary key). As you can see, it takes the nice syntax from Doctrine, and adds a bit more. The release is planned for the end of Q1 2010, but you can test it now in your Symfony projects.
  • phidah
    phidah over 14 years
    Nice input, I didn't know that :-)
  • Marek Karbarz
    Marek Karbarz over 14 years
    in Doctrine you can override setters and getters for each property and also have custom logic (see doctrine-project.org/documentation/manual/1_2/en/… - search for ATTR_AUTO_ACCESSOR_OVERRIDE to get to the relevant section)
  • allnightgrocery
    allnightgrocery over 14 years
    That looks ok, but you still set the property by calling: $x->propname = 'abc'; This is problematic because it doesn't appear to support passing multiple parameters.
  • Tom
    Tom about 14 years
    @Mike: thanks, didn't know about the plugin but seems it only supports up to Sf1.2. I ended up going with Doctrine in the end, feels like it was the right choice, although writing direct SQL is needed for the more complex stuff.
  • Trevor Allred
    Trevor Allred over 13 years
    A stable version of Doctrine 2 was recently released. doctrine-project.org/blog/doctrine2-released
  • Clement Herreman
    Clement Herreman over 11 years
    -1 Autocompletion of an IDE shouldn't be the reason of a technical choice
  • Sepster
    Sepster over 11 years
    @ClementHerreman I agree it shouldn't be the criteria, but I believe how productive one can be with a particular technology should certainly be a reason for choosing it. And with all-due respect I therefore disagree with your downvote... regardless of if you agree with the answer, it's not "wrong" (or is it?), and it is of some use (unless it's wrong, in which case, you should state this).
  • Clement Herreman
    Clement Herreman over 11 years
    IMO if your productivity is more improved by autocompletion instead of software quality, intuitivity and consistency, then something weird is happening. See codinghorror.com/blog/2009/01/…. But you're right, at some point this answer isn't wrong, just not good enough, maybe even not good.
  • mindplay.dk
    mindplay.dk over 11 years
    For the record, this comparison is totally outdated - current version of Propel does use PDO, does use support many-to-many relationships, and has great documentation. Also worth considering: some of us prefer the verbose criteria-builder query-style over proprietary query languages like DQL - it has IDE support, and it's a class, so you can extend it. I'm still trying to choose, but I see a lot of plus'es for Propel over Doctrine, if you don't mind static code-generation and can see the advantages of "real" PHP code as opposed to proprietary query-language, which is just strings to an IDE.
  • SoWhat
    SoWhat about 11 years
    doctrine implementation seems much more complex to me. Get Entity manage get repository... this and that
  • amd
    amd over 9 years
    @ClementHerreman, if isn't helpful don't use it anymore ;), +1
  • Qiniso
    Qiniso about 9 years
    Are there any up to date responses to this? This is way out of date.
  • Geomorillo
    Geomorillo over 7 years
    doctrine is over complicating things... just notorm is the way to go
  • Crouching Kitten
    Crouching Kitten over 6 years
    I don't agree with Clement. Regarding development the IDE is the most important factor.
  • Ryan Rentfro
    Ryan Rentfro almost 6 years
    When you are working with a project that has over 600 tables auto-completion of an IDE is a reason to make a technical choice. The technical choice being in the range of 10's to 100's of thousands of dollars on time wasted referencing documentation or raw schema.