搜尋
首頁後端開發php教程常見 php orm框架與簡單程式碼實現

物件關係映射(Object Relational Mapping,簡稱ORM)是一種為了解決物件導向與關聯式資料庫存在的互不符的現象的技術。 簡單的說,ORM是透過使用描述物件和資料庫之間映射的元數據,將程式中的物件自動持久化到關聯式資料庫中。本質上就是將資料從一種形式轉換到另外一種形式。

ORM提供了所有SQL語句的生成,程式碼人員遠離了資料庫概念。從一個概念需求(例如一個HQL)映射為一個SQL語句,並不需要什麼代價,連1%的效能損失都沒有。真正的效能損失在映射過程中,更具體地講,是在物件實例化的過程中。

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

1、Propel

Propel是一個適用於PHP5的ORM映射(Object Relational Mapping)框架,它基於Apache Torque提供物件持久層支援。它透過XML格式的模式定義檔和對應的設定檔來產生SQL和類,它允許你使用物件取代SQL來讀寫資料庫表中的記錄。 Propel提供一個生成器來為你的資料模型建立SQL定義檔和PHP類。開發者也可以十分簡單的客製化產生的類,我們還可以透過XML, PHP類和Phing建置工具把Propel整合到已有的應用開發框架中去.例如PHP框架symfony的1.2以前的版本就是預設使用了精簡版的Propel作為預設ORM框架。

官方網站:http://www.propelorm.org/

2、Doctrine

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/

3、EZPDO

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

官方網站:http://www.ezpdo.net/

4、RedBean

RedBean是一個易於使用,輕量級PHP ORM框架,提供對MySQL, SQLite&PostgreSQL的支援。 RedBean架構非常靈活,核心也非常簡約,開發者可以很方便的透過外掛程式來擴充功能。

官方網站:http://www.redbeanphp.com/

5、其他

國內的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 = &#39;id&#39;;
   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(&#39;127.0.0.1&#39;,&#39;root&#39;,&#39;&#39;) ;
       $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 .= &#39;`&#39;.$k.&#39;`,&#39;;
           }
           $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(&#39;$this->&#39;.$member.&#39; = &#39;.$value.&#39;;&#39;);
                 }else{
                     eval(&#39;$this->&#39;.$member.&#39; = "&#39;.$value.&#39;";&#39;);
                 }
              }
           }
       }
       $this->is_load = true;
   }
   public function __call($method,$param){
      $type   = substr($method,0,3);
      $member = substr($method,3);
      switch($type){
         case &#39;get&#39;:
             return $this->getMember($member);
             break;
         case &#39;set&#39;:
             return $this->setMember($member,$param[0]);
      }
      return false;
   }
   public function setMember($key){
       if(property_exists($this,$key)){
          if(is_numeric($val)){
             eval(&#39;$this->&#39;.$key.&#39; = &#39;.$val.&#39;;&#39;);
          }else{
             eval(&#39;$this->&#39;.$key.&#39; = "&#39;.$val.&#39;";&#39;);
          }
          $this->_modifyMap[$key] = 1;
       }else{
          return false;
       }
   }
   
   public function getMember($key,$val){
       if(!$this->is_load){
          $this->Load();
       }
       if(property_exists($this,$key)){
          eval(&#39;$res = $this->&#39;.$key.&#39;;&#39; );
          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( &#39;$val = $this->&#39;.$v2.&#39;;&#39;);
                  $sql_update .=  $v2." = ".$val;
              }
          }
          $sql .= substr($sql_update,0,strlen($sql_update));
          $sql .= &#39;WHERE &#39;.$this->pk.&#39; = &#39;.$this->_ID;
      }else{
          $sql = "INSERT INTO ".$this->_tableName." (";
          foreach($this->arRelationMap as $k3 => $v3){
              if(array_key_exists( $k3,$this->_modifyMap)){
                  eval(&#39;$val = $this->&#39;.$v3.&#39;;&#39;);
                  $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( 
                      &#39;id&#39;       => USER_ID,
                      &#39;user_name&#39;=> USER_NAME,
                      &#39;user_age&#39; => USER_AGE
                    );
    }
    public function getDB(){
       return $this->_DB;
    }
}
$UserIns = new User();
print_r($UserIns);
?>


陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
可以在PHP會話中存儲哪些數據?可以在PHP會話中存儲哪些數據?May 02, 2025 am 12:17 AM

phpsessionscanStorestrings,數字,數組和原始物。

您如何開始PHP會話?您如何開始PHP會話?May 02, 2025 am 12:16 AM

tostartaphpsession,usesesses_start()attheScript'Sbeginning.1)placeitbeforeanyOutputtosetThesessionCookie.2)useSessionsforuserDatalikeloginstatusorshoppingcarts.3)regenerateSessiveIdStopreventFentfixationAttacks.s.4)考慮使用AttActAcks.s.s.4)

什麼是會話再生,如何提高安全性?什麼是會話再生,如何提高安全性?May 02, 2025 am 12:15 AM

會話再生是指在用戶進行敏感操作時生成新會話ID並使舊ID失效,以防會話固定攻擊。實現步驟包括:1.檢測敏感操作,2.生成新會話ID,3.銷毀舊會話ID,4.更新用戶端會話信息。

使用PHP會話時有哪些性能考慮?使用PHP會話時有哪些性能考慮?May 02, 2025 am 12:11 AM

PHP会话对应用性能有显著影响。优化方法包括:1.使用数据库存储会话数据,提升响应速度;2.减少会话数据使用,只存储必要信息;3.采用非阻塞会话处理器,提高并发能力;4.调整会话过期时间,平衡用户体验和服务器负担;5.使用持久会话,减少数据读写次数。

PHP會話與Cookie有何不同?PHP會話與Cookie有何不同?May 02, 2025 am 12:03 AM

PHPsessionsareserver-side,whilecookiesareclient-side.1)Sessionsstoredataontheserver,aremoresecure,andhandlelargerdata.2)Cookiesstoredataontheclient,arelesssecure,andlimitedinsize.Usesessionsforsensitivedataandcookiesfornon-sensitive,client-sidedata.

PHP如何識別用戶的會話?PHP如何識別用戶的會話?May 01, 2025 am 12:23 AM

phpIdentifiesauser'ssessionSessionSessionCookiesAndSessionId.1)whiwsession_start()被稱為,phpgeneratesainiquesesesessionIdStoredInacookInAcookInAcienamedInAcienamedphpsessIdontheuser'sbrowser'sbrowser.2)thisIdallowSphptpptpptpptpptpptpptpptoretoreteretrieetrieetrieetrieetrieetrieetreetrieetrieetrieetrieetremthafromtheserver。

確保PHP會議的一些最佳實踐是什麼?確保PHP會議的一些最佳實踐是什麼?May 01, 2025 am 12:22 AM

PHP會話的安全可以通過以下措施實現:1.使用session_regenerate_id()在用戶登錄或重要操作時重新生成會話ID。 2.通過HTTPS協議加密傳輸會話ID。 3.使用session_save_path()指定安全目錄存儲會話數據,並正確設置權限。

PHP會話文件默認存儲在哪裡?PHP會話文件默認存儲在哪裡?May 01, 2025 am 12:15 AM

phpsessionFilesArestoredIntheDirectorySpecifiedBysession.save_path,通常是/tmponunix-likesystemsorc:\ windows \ windows \ temponwindows.tocustomizethis:tocustomizEthis:1)useession_save_save_save_path_path()

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器