codeigniter下ORM的擴(kuò)展

一,什么是ORM?

  • Object Relation Mapping的簡(jiǎn)寫(xiě),一般稱作“對(duì)象關(guān)系映射”。
  • 在Web開(kāi)發(fā)中最常用于和關(guān)系型數(shù)據(jù)庫(kù)交互的地方。接口、中間件、庫(kù)、包,你都可以這么稱呼它。
  • 比如:MySQL的一張表映射成一個(gè)PHP類(模型model),表的字段就是這個(gè)類的成員變量。那么這個(gè)中間操作就是ORM。

相信大家都知道,codeigniter是一個(gè)輕量級(jí)的框架,并不支持ORM,那么以下是本人根據(jù)自己的實(shí)際項(xiàng)目,在codeigniter上做的ORM擴(kuò)展.

二,在ci本身連接數(shù)據(jù)庫(kù)基礎(chǔ)上擴(kuò)展

  • system/database/drivers/mysql 目錄下新建 curd_driver.php 讓其繼承 mysql_driver,也就是擴(kuò)展mysql的數(shù)據(jù)庫(kù)驅(qū)動(dòng);
  • 在curd_driver.php中新增getObj方法,在getObj方法中new具體實(shí)體類, 通過(guò)調(diào)用parent::get()方法查詢數(shù)據(jù)庫(kù)數(shù)據(jù), 然后做到數(shù)據(jù)庫(kù)數(shù)據(jù)映射為實(shí)體類對(duì)象并返回,使用方式:
$this->db->from('wiki_key')->where(array('id'=>$wikiKeyId))->order_by('id','desc')->limit(1)->initAttr(array(1));                          
$rowObj = $this->db->getObj();
  • 在curd_driver.php中新增save(obj)保存記錄,對(duì)象id非空則修改,否則新增操作, 新增destory(obj)方法刪除對(duì)象,使用方式:
//保存對(duì)象
$rowObj->name='zhangsan';
$res = $this->db->save($rowObj);
//銷毀對(duì)象
$res = $this->db->destory($rowObj);
  • 實(shí)體類文件寫(xiě)在libraris目錄下,統(tǒng)一繼承ORM抽象類,每個(gè)實(shí)體類包含所有數(shù)據(jù)表屬性;

  • system/database/DB.php 140修改,判斷如果ci使用的數(shù)據(jù)庫(kù)驅(qū)動(dòng)是mysql,則將加載mysql_driver修改為加載curd_driver,具體如下:

 require_once(BASEPATH.'database/drivers/'.$params['dbdriver'].'/'.$params['dbdriver'].'_driver.php');    
//liangxifeng 2015-06-05  添加ORM控制類
$params['dbdriver_tmp'] = $params['dbdriver'];
if($params['dbdriver']=="mysql")
   {  
       require_once(BASEPATH.'database/drivers/'.$params['dbdriver'].'/curd_driver.php');
        $params['dbdriver_tmp'] = "curd";
    }   
    // Instantiate the DB adapter
    $driver = 'CI_DB_'.$params['dbdriver_tmp'].'_driver';
    $DB = new $driver($params);

具體實(shí)現(xiàn)圖解如下:

ci-orm-class
ci-orm-class

ci-orm-squence
ci-orm-squence

三,在ci基于REST的三層架構(gòu)中的BLL層擴(kuò)展

  • 在libraries中新增REST_Curd.php讓其繼承REST_Client.php, 重寫(xiě)父類的get方法,在get中new具體實(shí)體類, 通過(guò)調(diào)用parent::get()方法調(diào)用遠(yuǎn)程DAL數(shù)據(jù), 然后做到DAL數(shù)據(jù)映射為實(shí)體類對(duì)象并返回,使用方式:
//查詢多條數(shù)據(jù)
$inParamList = array('data'=>array('where'=>array('batch_id >= '=>1), 'order'=>'batch_id asc','limit'=>10));
$inParamList['type'] = 'list';
$batchArrayObj = $this->rest_client->get('ticket/ticket_batchs',$inParamList,1);
//查詢單條數(shù)據(jù)
$batchRowObj = $this->rest_client->get('ticket/ticket_batch',array('id'=>1,'field'=>'batch_id,batch_price,batch_name'),1);
  • 實(shí)體類文件寫(xiě)在libraris目錄下,實(shí)體類需要包含所有數(shù)據(jù)表結(jié)構(gòu)字段屬性,統(tǒng)一繼承ORM抽象類;
  • 在ORM類中做對(duì)象的保存save() 和 對(duì)象銷毀destroy()操作,使用方式:
//在原有查詢數(shù)據(jù)對(duì)象基礎(chǔ)上save
$batchRowObj->batch_name='lisi';
$this->batchRowObj->save();
//或new空對(duì)象進(jìn)行save
$this->load->library('ticket/ticket_batch',array(),'batchObj');
$this->batchObj->batch_name = 'test2';
$this->batchObj->save();
//銷毀對(duì)象
$this->batchObj->destroy();

具體實(shí)現(xiàn)圖解如下:

ci-orm-bll-class
ci-orm-bll-class

ci-orm-bll-squence
ci-orm-bll-squence
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容