看板 PHP 關於我們 聯絡資訊
其實敝人對於設計模式大致還有很多的不了解。 只是就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:http://datamapper.wanwizard.eu/ 07/21 12:20
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