一,什么是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-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-squence