High performance data-mapper ORM with optional active-record traits for RAD and modern PHP 7.1+

dev-master / 3.0.x-dev 2017-11-07 03:55 UTC


Propel3 is an open-source Object-Relational Mapping (ORM) for modern PHP 7.1+.

It is also written and maintained by people better and smarter than I am-- there wasn't an existing Propel3 on packagist.

So, this github repo and packagist entry exists solely for me to put into my PHP package.json, you are free to use it. But, know that once a valid propelorm/propel3 packagist package becomes available that I will begin using that and not maintaining this one.

Build Status Code Climate 68747470733a2f2f636f6465636c696d6174652e636f6d2f6769746875622f70726f70656c6f726d2f50726f70656c322f6261646765732f636f7665726167652e737667 PPM Compatible Gitter

Version 3 of Propel ORM replaces Propel2, which is not maintained anymore. Propel3 introduces a data-mapper implementation which separates your entities from the actual persisting logic.


This is in current development and is not yet ready to use.


  • Propel is blazing fast
  • Data mapper with runtime UnitOfWork for high performance with massive object counts (bulks inserts/updates)
  • Query-Builder
  • Very IDE friendly thanks to code-generation
  • Generation of methods for all columns and relations
  • Database schema migration
  • Schema reverse engineering
  • Customizable
  • Propel comes with common ‘behaviors’
  • Completely unit tested for MySQL, PostgreSQL, SQLite. Oracle and MSSQL are experimental.


Define the entity

<database name="default">
  <entity name="Vendor\Car">
      <field name="id" primaryKey="true" autoIncrement="true" type="INTEGER" />
      <field name="name" type="VARCHAR" required="true"  />
      <relation target="Publisher" onDelete="setnull"/>
      <relation target="Author" onDelete="setnull" onUpdate="cascade"/>
or annotations

In work.

namespace Vendor

use Propel\Annotations\Entity;
use Propel\Annotations\Field;
use Propel\Annotations\PrimaryKey;

 * @Entity()
class Car
     * @PrimaryKey(auto_increment=true)
    private $id;
     * @Field(type="VARCHAR")
    private $name;
    // getters/setters

Data mapper

$propel = new Propel\Runtime\Configuration('path/to/propel.yml');

// require a session for each request/workload
$session = $propel->getSession();

$car = new Vendor\Car();



// use <entity name="Vendor\Car" activeRecord="true">
$car = new Vendor\Car();


Read the Propel documentation. This documentation is for Propel2 still.


Everybody can contribute to Propel. Just fork it, and send Pull Requests. You have to follow PSR2 conding standards and provides unit tests as much as possible.

Please see our contribution guideline. Thank you!


See the LICENSE file.