[心得] 基於CI的model,不同資料表或資料選擇ꨠ…

看板PHP作者 (皮皮快跑)時間14年前 (2011/07/20 23:07), 編輯推噓4(408)
留言12則, 6人參與, 最新討論串1/1
其實敝人對於設計模式大致還有很多的不了解。 只是就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
不用datamapper嗎...?很方便說
07/20 23:19, 1F

07/21 00:48, , 2F
團隊開發,導入ORM是必要的,效能和效率如熊掌與魚(嘆)
07/21 00:48, 2F

07/21 00:49, , 3F
1F所提的datamapper目前版本有支援CI2以上嗎?
07/21 00:49, 3F

07/21 06:05, , 4F
有啊 正在用
07/21 06:05, 4F

07/21 12:20, , 5F

07/21 12:20, , 6F
最後更新版本 1.8.2 2011/06/07 Release
07/21 12:20, 6F

07/21 15:04, , 7F
Codelgniter sparks 是?
07/21 15:04, 7F

07/22 17:13, , 8F
datamapper 應該不是用再分散式資料庫架構?
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
不懂樓上的意思?原PO好像沒提到分散式資料庫架構
07/22 21:06, 11F

07/22 21:41, , 12F
amosa該不是發生....鍵盤爆走事件?
07/22 21:41, 12F
文章代碼(AID): #1E9kyU44 (PHP)
文章代碼(AID): #1E9kyU44 (PHP)