目前PHP 开源比较有名的 ORM 有如下几个:php
Propel是一个适用于PHP5的ORM映射(Object Relational Mapping)框架,它基于Apache Torque提供对象持久层支持。它经过XML格式的模式定义文件和相应的配置文件来生成SQL和类,它容许你使用对象代替SQL来读写数据库表中的记 录。Propel提供一个生成器来为你的数据模型建立SQL定义文件和PHP类。开发者也能够十分简单的定制生成的类,咱们还能够经过XML, PHP类和Phing构建工具把Propel集成到已有的应用开发框架中去.例如PHP框架symfony的1.2之前的版本就是默认使用了精简版的 Propel做为默认ORM框架。mysql
官方网站:http://www.propelorm.org/sql
Doctrine是一个PHP的ORM框架,它必须运行在>=php5.2.3版本上,它是一个功能强大的数据抽象层。数据库
它的一个主要特征就是使用面向对象的方式来实现数据库查询的封转,它底层经过一个相似 Hibernate HQL的DQL的查询语句进行数据库查询,这使得开发的灵活性更强,大大减少了重复代码。相比Propel,Doctrine的优势在于它支持支持全文检 索,Doctrine的文档一直就比Propel要全面丰富,社区更活跃,并且使用起来更加天然、更易阅读、更接近原生SQL。性能方面也略微优于 Propel。一样你也能够能够很方便的把Doctrine集成到现有的应用框架中去,好比PHP框架symfony的1.3之后的版本将 Doctrine做为默认的ORM框架,同时也能够将Doctrine和Codeigniter整合起来。缓存
官方网站: http://www.doctrine-project.org/架构
EZPDO是一个十分轻量级的PHP ORM框架。EZPDO的做者的本意旨在下降复杂的ORM学习曲线,尽量在ORM的运行效率和功能之间作一个平衡点,它是我至今用过的最简单的ORM框 架,我目前还想将它集成到个人CoolPHP SDK中来,并且运行效率至关不错,功能也基本能知足需求,只不过ESPDO的更新比较缓慢。app
官方网站:http://www.ezpdo.net/blog/?p=2框架
RedBean是一个易于使用,轻量级PHP ORM框架,提供对MySQL, SQLite&PostgreSQL的支持。RedBean架构很是灵活,核心也很是简约,开发者能够很方便的经过插件来扩展功能。工具
官方网站:http://www.redbeanphp.com/性能
国内的fleaphp开发框架基于TableDataGateway实现ORM实现;Zend Framework除了提供对 SQL 语句的封装之外,也一样实现了TableGateway、TableRowSet、TableRow的实现;还有一些相似Rails的 ActiveRecord实现的解决方案。
总的来讲,通常ORM框架对付简单的应用系统来讲都能知足基本需求,能够大大下降开发难度,提升开发效率,可是它在SQL优化方面,确定是比纯 SQL语言要差一些,对复杂关联、SQL内嵌表达式的处理可能不是很理想。也许这主要是因为PHP自己对象持久化的问题,致使ORM效率太低,广泛比纯 SQL要慢。可是这些都是有办法解决的,最基本的解决性能的方案,咱们能够经过缓存来提升效率,Hibernate来讲,虽然配置比较繁杂,可是它经过灵 活的使用二级缓存和查询缓存极大的缓解数据库的查询压力,极大的提高了系统的性能。
若是你想本身实现一个PHP的ORM,下面的能够参考下:
<?php abstract class Model{ protected $pk = 'id'; protected $_ID = null; protected $_tableName; protected $_arRelationMap; protected $_modifyMap; protected $is_load = false; protected $_blForDeletion; protected $_DB; public function __consturct($id = null){ $this->_DB = mysql_connect('127.0.0.1','root','') ; $this->_tableName = $this->getTableName(); $this->_arRelationMap = $this->getRelationMap(); if(isset($id))$this->_ID = $id; } abstract protected function getTableName(); abstract protected function getRelationMap(); public function Load(){ if(isset($this->_ID)){ $sql = "SELECT "; foreach($this->_arRelationMap as $k => $v){ $sql .= '`'.$k.'`,'; } $sql .= substr($sql,0,strlen($sql)-1); $sql .= "FROM ".$this->_tableName." WHERE ".$this->pk." = ".$this->_ID; $result =$this->_DB->mysql_query($sql); foreach($result[0] as $k1 => $v1){ $member = $this->_arRelationMap[$key]; if(property_exists($this,$member)){ if(is_numeric($member)){ eval('$this->'.$member.' = '.$value.';'); }else{ eval('$this->'.$member.' = "'.$value.'";'); } } } } $this->is_load = true; } public function __call($method,$param){ $type = substr($method,0,3); $member = substr($method,3); switch($type){ case 'get': return $this->getMember($member); break; case 'set': return $this->setMember($member,$param[0]); } return false; } public function setMember($key){ if(property_exists($this,$key)){ if(is_numeric($val)){ eval('$this->'.$key.' = '.$val.';'); }else{ eval('$this->'.$key.' = "'.$val.'";'); } $this->_modifyMap[$key] = 1; }else{ return false; } } public function getMember($key,$val){ if(!$this->is_load){ $this->Load(); } if(property_exists($this,$key)){ eval('$res = $this->'.$key.';' ); return $this->$key; } return false; } public function save(){ if(isset($this->_ID)){ $sql = "UPDATE ".$this->_tableName." SET "; foreach($this->arRelationMap as $k2 => $v2){ if(array_key_exists( $k2, $this->_modifyMap)){ eval( '$val = $this->'.$v2.';'); $sql_update .= $v2." = ".$val; } } $sql .= substr($sql_update,0,strlen($sql_update)); $sql .= 'WHERE '.$this->pk.' = '.$this->_ID; }else{ $sql = "INSERT INTO ".$this->_tableName." ("; foreach($this->arRelationMap as $k3 => $v3){ if(array_key_exists( $k3,$this->_modifyMap)){ eval('$val = $this->'.$v3.';'); $field .= "`".$v3."`,"; $values .= $val; } } $fields = substr($field,0,strlen($field)-1); $vals = substr($values,0,strlen($values)-1); $sql .= $fields." ) VALUES (".$vals.")"; } echo $sql; //$this->_DB->query($sql); } public function __destory(){ if(isset($this->ID)){ $sql = "DELETE FROM ".$this->_tableName." WHERE ".$this->pk." = ".$this->_ID; // $this->_DB_query($sql); } } } class User extends Model{ protected function getTableName(){ return "test_user"; } protected function getRelationMap(){ return array( 'id' => USER_ID, 'user_name'=> USER_NAME, 'user_age' => USER_AGE ); } public function getDB(){ return $this->_DB; } } $UserIns = new User(); print_r($UserIns); ?>