日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

常見 PHP ORM 框架與簡單代碼實現(xiàn)

瀏覽:118日期:2022-09-13 14:02:08

對象關(guān)系映射(Object Relational Mapping,簡稱ORM)是一種為了解決面向?qū)ο笈c關(guān)系數(shù)據(jù)庫存在的互不匹配的現(xiàn)象的技術(shù)。 簡單的說,ORM是通過使用描述對象和數(shù)據(jù)庫之間映射的元數(shù)據(jù),將程序中的對象自動持久化到關(guān)系數(shù)據(jù)庫中。本質(zhì)上就是將數(shù)據(jù)從一種形式轉(zhuǎn)換到另外一種形式。

ORM提供了所有SQL語句的生成,代碼人員遠離了數(shù)據(jù)庫概念。從一個概念需求(例如一個HQL)映射為一個SQL語句,并不需要什么代價,連1%的性能損失都沒有。真正的性能損失在映射過程中,更具體地講,是在對象實例化的過程中。

目前PHP 開源比較有名的 ORM 有以下幾個:

1、Propel

Propel是一個適用于PHP5的ORM映射(Object Relational Mapping)框架,它基于Apache Torque提供對象持久層支持。它通過XML格式的模式定義文件和相應(yīng)的配置文件來生成SQL和類,它允許你使用對象代替SQL來讀寫數(shù)據(jù)庫表中的記錄。Propel提供一個生成器來為你的數(shù)據(jù)模型創(chuàng)建SQL定義文件和PHP類。開發(fā)者也可以十分簡單的定制生成的類,我們還可以通過XML, PHP類和Phing構(gòu)建工具把Propel集成到已有的應(yīng)用開發(fā)框架中去.例如PHP框架symfony的1.2以前的版本就是默認使用了精簡版的Propel作為默認ORM框架。

官方網(wǎng)站:http://www.propelorm.org/

2、Doctrine

Doctrine是一個PHP的ORM框架,它必須運行在>=php5.2.3版本上,它是一個功能強大的數(shù)據(jù)抽象層。

它的一個主要特征就是使用面向?qū)ο蟮姆绞絹韺崿F(xiàn)數(shù)據(jù)庫查詢的封轉(zhuǎn),它底層通過一個類似 Hibernate HQL的DQL的查詢語句進行數(shù)據(jù)庫查詢,這使得開發(fā)的靈活性更強,大大減小了重復(fù)代碼。相比Propel,Doctrine的優(yōu)點在于它支持支持全文檢索,Doctrine的文檔一直就比Propel要全面豐富,社區(qū)更活躍,而且使用起來更加自然、更易閱讀、更接近原生SQL。性能方面也略微優(yōu)于Propel。同樣你也可以可以很方便的把Doctrine集成到現(xiàn)有的應(yīng)用框架中去,比如PHP框架symfony的1.3以后的版本將Doctrine作為默認的ORM框架,同時也可以將Doctrine和Codeigniter整合起來。

官方網(wǎng)站: http://www.doctrine-project.org/

3、EZPDO

EZPDO是一個十分輕量級的PHP ORM框架。EZPDO的作者的本意旨在降低復(fù)雜的ORM學(xué)習(xí)曲線,盡可能在ORM的運行效率和功能之間做一個平衡點,它是我至今用過的最簡單的ORM框架,我目前還想將它集成到我的CoolPHP SDK中來,而且運行效率相當(dāng)不錯,功能也基本能滿足需求,只不過EZPDO的更新比較緩慢。

官方網(wǎng)站:http://www.ezpdo.net/

4、RedBean

RedBean是一個易于使用,輕量級PHP ORM框架,提供對MySQL, SQLite&PostgreSQL的支持。RedBean架構(gòu)非常靈活,核心也非常簡約,開發(fā)者可以很方便的通過插件來擴展功能。

官方網(wǎng)站:http://www.redbeanphp.com/

5、其他

國內(nèi)的fleaphp開發(fā)框架基于TableDataGateway實現(xiàn)ORM實現(xiàn);Zend Framework除了提供對 SQL 語句的封裝以外,也同樣實現(xiàn)了TableGateway、TableRowSet、TableRow的實現(xiàn);還有一些類似Rails的ActiveRecord實現(xiàn)的解決方案。

總的來說,一般ORM框架對付簡單的應(yīng)用系統(tǒng)來說都能滿足基本需求,可以大大降低開發(fā)難度,提高開發(fā)效率,但是它在SQL優(yōu)化方面,肯定是比純SQL語言要差一些,對復(fù)雜關(guān)聯(lián)、SQL內(nèi)嵌表達式的處理可能不是很理想。也許這主要是由于PHP本身對象持久化的問題,導(dǎo)致ORM效率過低,普遍比純SQL要慢。但是這些都是有辦法解決的,最基本的解決性能的方案,我們可以通過緩存來提高效率,Hibernate來說,雖然配置比較繁雜,但是它通過靈活的使用二級緩存和查詢緩存極大的緩解數(shù)據(jù)庫的查詢壓力,極大的提升了系統(tǒng)的性能。

如果你想自己實現(xiàn)一個PHP的ORM,下面的可以參考下:

<?phpabstract 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);?>

標(biāo)簽: PHP
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美成人精品| 欧美色综合网| 欧美天堂视频| 国产欧美二区| 久久99国产精品视频| 免费在线欧美黄色| 美女精品久久| av在线资源| 99精品网站| 不卡在线一区| 免费国产自久久久久三四区久久| 日本欧美不卡| 久久视频精品| 亚洲视频播放| 视频一区中文字幕精品| 日韩制服丝袜先锋影音| 视频一区日韩精品| 国产日本精品| 激情久久一区二区| 美女一区网站| 国产亚洲精品久久久久婷婷瑜伽| 日韩在线一二三区| 欧美精品中文| 97精品中文字幕| 亚洲国产一区二区三区在线播放 | 激情综合五月| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 美女91精品| 欧美在线91| 日本不良网站在线观看| 亚洲一级黄色| 日本不卡视频在线| 精品国产91| 国产亚洲毛片在线| 国产精品男女| 欧美jjzz| 国产欧美日韩| 亚洲国产专区校园欧美| 日韩精品电影一区亚洲| 91亚洲国产高清| 久久99伊人| 国产日韩一区二区三区在线播放| 成人综合一区| 亚洲一区区二区| 国产精品久久久久久模特| 在线看片国产福利你懂的| 免费欧美日韩| 国产精品伦一区二区| 亚洲国产综合在线看不卡| 日韩激情一区二区| 欧美天堂视频| 日本va欧美va欧美va精品| 亚洲黄色网址| 日韩一区二区三区四区五区| caoporn视频在线| 亚洲精品少妇| 中文字幕在线看片| 亚洲精品一级二级三级| 麻豆视频在线观看免费网站黄 | 在线综合视频| 久久免费精品| 一区二区91| 日韩大片在线播放| 日韩二区三区四区| 亚洲三级观看| 久久久国产精品网站| 欧美精品一线| 美女精品久久| 免费久久99精品国产| 久久99蜜桃| 亚洲一区中文| 四季av一区二区凹凸精品| 蜜臀国产一区二区三区在线播放| 国产成人77亚洲精品www| 亚洲人成网77777色在线播放| 国产资源在线观看入口av| 欧美午夜三级| 手机精品视频在线观看| 日韩欧美精品综合| 国产毛片精品| 亚洲区欧美区| 婷婷亚洲五月色综合| 精品午夜av| 日韩毛片网站| 日韩视频在线一区二区三区| 精品国产一区二区三区av片| 中文字幕亚洲影视| 久久精品不卡| 国产精品xx| 美女视频一区在线观看| 亚洲精品女人| 久久国产精品毛片| 国产综合精品| 欧美日韩免费看片| 久久精品福利| 国产精品视频3p| 日韩精品欧美成人高清一区二区| 黄色日韩在线| 欧美色图国产精品| 成年男女免费视频网站不卡| 国产欧美日韩精品一区二区免费| 亚洲欧美在线综合| 视频一区中文字幕| 国产韩日影视精品| 久久久久一区| 天堂√中文最新版在线| 美腿丝袜在线亚洲一区| 日韩成人精品一区二区三区| 免费看的黄色欧美网站| 日韩精品一区二区三区免费观看| 免费日韩一区二区三区| 国产伦精品一区二区三区在线播放| 综合激情五月婷婷| 免费人成精品欧美精品 | 欧美激情三区| 欧美午夜精品一区二区三区电影| 日韩精品欧美| 久久五月天小说| 九九久久婷婷| 91精品观看| 亚洲一区激情| 亚洲日产国产精品| 日韩综合一区二区| 日韩三级视频| 欧美日韩亚洲国产精品| 欧美在线不卡| 欧美国产极品| 高清av一区| 亚洲黄色网址| 久久久777| 中国女人久久久| 三级在线观看一区二区| 亚洲欧美在线专区| 欧美精品观看| 欧美激情一区| 国产v日韩v欧美v| 久久久影院免费| 麻豆精品网站| 欧美天堂一区| 精品亚洲a∨一区二区三区18| 成人精品久久| 香蕉精品久久| 综合欧美精品| 日韩欧美另类中文字幕| 国产精品成人自拍| 国产精品黑丝在线播放| 欧美日韩在线观看视频小说| 黄色免费成人| 日韩成人一级| 国产成人免费av一区二区午夜| 精品视频黄色| 久久高清免费| 日韩专区欧美专区| 青青草伊人久久| 欧美xxxx中国| 午夜欧美精品| 青青草91视频| 超碰在线99| 樱桃成人精品视频在线播放| 综合激情婷婷| 精品国产不卡| 欧美日韩国产高清| 日韩高清欧美激情| 97精品97| 蜜臀久久久久久久| 国产精品乱战久久久| 精品国产亚洲日本| 99久久精品费精品国产| 国产成人精选| 蜜臀久久99精品久久一区二区| 亚洲婷婷丁香| 欧美激情麻豆| 久久视频精品| 亚洲欧美在线专区| 国产成人精选| 奶水喷射视频一区| 久久97视频| 麻豆亚洲精品| 精品入口麻豆88视频| 在线视频免费在线观看一区二区| 国产日韩视频| 午夜免费一区| 国产精东传媒成人av电影| 999视频精品| 国产视频一区二区在线播放| 久久青草久久| 国产亚洲精品美女久久| 国产精品v一区二区三区| 成人啊v在线| 欧美日本一区| 欧美国产91| 欧美黄页在线免费观看| 日韩一级欧洲| 国产一区二区久久久久| 美女尤物久久精品| av在线资源| 国产欧美日韩精品一区二区三区| 亚洲香蕉网站| 精品亚洲精品| 日韩在线电影|