[心得] 基於CI的model,不同資料表或資料選擇ꨠ…
其實敝人對於設計模式大致還有很多的不了解。
只是就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)
→
07/20 23:19, , 1F
07/20 23:19, 1F
推
07/21 00:48, , 2F
07/21 00:48, 2F
→
07/21 00:49, , 3F
07/21 00:49, 3F
→
07/21 06:05, , 4F
07/21 06:05, 4F
推
07/21 12:20, , 5F
07/21 12:20, 5F
→
07/21 12:20, , 6F
07/21 12:20, 6F
推
07/21 15:04, , 7F
07/21 15:04, 7F
推
07/22 17:13, , 8F
07/22 17:13, 8F
→
07/22 17:14, , 9F
07/22 17:14, 9F
→
07/22 17:15, , 10F
07/22 17:15, 10F
→
07/22 21:06, , 11F
07/22 21:06, 11F
→
07/22 21:41, , 12F
07/22 21:41, 12F
PHP 近期熱門文章
PTT數位生活區 即時熱門文章
154
159