作者tkdmaf (皮皮快跑)
看板PHP
標題[心得] 基於CI的model,不同資料表或資料選擇的替換模式。
時間Wed Jul 20 23:07:08 2011
其實敝人對於設計模式大致還有很多的不了解。
只是就model的方法因為實在覺得不斷的開方法一直寫也不是個對策。
尤其對應到不同的資料表就要重設一次model也挺麻煩的。
之前有做共用繼承某些特定模式,但事實上有的時候對資料的搜尋條件並不是那麼
的單一或單純。
以下針對取得某筆單一資料的做法提供參考。
my_model.php(direct is models)
-------------------------------
class my_model extends model{
var table;
function my_model(){
parent::model();
}
function select_row($id,$ob_model = 'md_user'){
$this->load->library($ob_model);
$this->$ob_model->db = $this->db;
return $this->$ob_model->row($id);
}
}
md_user.php(direct is libraries)
--------------------------------
class md_user{
var $db;
var $table = 'user';
function md_user(){
}
function row($id){
$this->db->where('id',$id);
$query = $this->db->get($this->table);
if($query->num_rows() != 0)
return $query->row();
return false;
}
}
主程式使用時:
假設設定model:$this->load->model('my_model','MYMODEL',TRUE);
function show_user_data(){
$data['row'] = $this->MYMODEL->select_row($id,'md_user');
$this->load->view('show_user_data',$data);
}
這個模式的寫法是說,在主程式僅需要載入一個model。
而不需要為了不同的model去寫很多model(往往其實不同的model檔案功能都差不多)
方法上來說,取得單筆資料就是一個select_row()的功能。
至於功能要傳回什麼,全看library的物件怎麼去闡述需要的條件。
有的時候可能是關聯式資料的查詢回傳。
有的時候也許會是複合性條件。
但不管是什麼,只要是取得多筆資料可能就統一行為叫做select_query()
取得單筆就統一行為叫做select_row()
至於怎麼查,查詢的條件,查什麼資料表,就交給library物件去實做就行了。
之所以會寫這個其實只是最近寫ci覺得針對不同的查詢要再開新的method真的不是
個好的策略。而且會造成model物件過度複雜化。
裡頭的功能寫太多,單純回頭看起來要嘛也不過就是要個物件集合。
要嘛也不過就是要一個單一資料物件。
何不乾脆就把主功能純化掉。
把不同的功能交給不同的物件去處理就好了。
重要的是:我要的就只是個資料結果而已。
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 59.104.131.235
※ 編輯: tkdmaf 來自: 59.104.131.235 (07/20 23:08)
→ superpai:不用datamapper嗎...?很方便說 07/20 23:19
推 liaosankai:團隊開發,導入ORM是必要的,效能和效率如熊掌與魚(嘆) 07/21 00:48
→ liaosankai:1F所提的datamapper目前版本有支援CI2以上嗎? 07/21 00:49
→ superpai:有啊 正在用 07/21 06:05
→ appleboy46:最後更新版本 1.8.2 2011/06/07 Release 07/21 12:20
推 hazih:Codelgniter sparks 是? 07/21 15:04
推 amosa:datamapper 應該不是用再分散式資料庫架構? 07/22 17:13
→ amosa:不適用* 再分散式資料庫架構? 07/22 17:14
→ amosa:不適用* 在*分散式資料庫架構? ..(暗..) 07/22 17:15
→ liaosankai:不懂樓上的意思?原PO好像沒提到分散式資料庫架構 07/22 21:06
→ tkdmaf:amosa該不是發生....鍵盤爆走事件? 07/22 21:41