一,什么是ORM?
- Object Relation Mapping的簡寫例朱,一般稱作“對象關系映射”孝情。
- 在Web開發(fā)中最常用于和關系型數據庫交互的地方。接口洒嗤、中間件箫荡、庫、包渔隶,你都可以這么稱呼它羔挡。
- 比如:MySQL的一張表映射成一個PHP類(模型model),表的字段就是這個類的成員變量间唉。那么這個中間操作就是ORM绞灼。
相信大家都知道,codeigniter是一個輕量級的框架呈野,并不支持ORM低矮,那么以下是本人根據自己的實際項目,在codeigniter上做的ORM擴展.
二被冒,在ci本身連接數據庫基礎上擴展
- system/database/drivers/mysql 目錄下新建 curd_driver.php 讓其繼承 mysql_driver,也就是擴展mysql的數據庫驅動军掂;
- 在curd_driver.php中新增getObj方法,在getObj方法中new具體實體類, 通過調用parent::get()方法查詢數據庫數據, 然后做到數據庫數據映射為實體類對象并返回昨悼,使用方式:
$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)保存記錄,對象id非空則修改,否則新增操作, 新增destory(obj)方法刪除對象蝗锥,使用方式:
//保存對象
$rowObj->name='zhangsan';
$res = $this->db->save($rowObj);
//銷毀對象
$res = $this->db->destory($rowObj);
實體類文件寫在libraris目錄下,統一繼承ORM抽象類幔戏,每個實體類包含所有數據表屬性玛追;
system/database/DB.php 140修改,判斷如果ci使用的數據庫驅動是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);
具體實現圖解如下:
三,在ci基于REST的三層架構中的BLL層擴展
- 在libraries中新增REST_Curd.php讓其繼承REST_Client.php, 重寫父類的get方法垒玲,在get中new具體實體類, 通過調用parent::get()方法調用遠程DAL數據, 然后做到DAL數據映射為實體類對象并返回陆馁,使用方式:
//查詢多條數據
$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);
//查詢單條數據
$batchRowObj = $this->rest_client->get('ticket/ticket_batch',array('id'=>1,'field'=>'batch_id,batch_price,batch_name'),1);
- 實體類文件寫在libraris目錄下,實體類需要包含所有數據表結構字段屬性合愈,統一繼承ORM抽象類叮贩;
- 在ORM類中做對象的保存save() 和 對象銷毀destroy()操作击狮,使用方式:
//在原有查詢數據對象基礎上save
$batchRowObj->batch_name='lisi';
$this->batchRowObj->save();
//或new空對象進行save
$this->load->library('ticket/ticket_batch',array(),'batchObj');
$this->batchObj->batch_name = 'test2';
$this->batchObj->save();
//銷毀對象
$this->batchObj->destroy();