本篇文章給大家帶來的內容是關於如何自訂一個Model?ThinkPHP3.2自訂基類Model的用法,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所協助。
ThinkPHP 提供了一個 Model 類,供其他的 Model 進行繼承。Model 類中是 MVC 中的模型類,它是調用 持久層 的上層類。感覺這麼描述問題很多,但是有什麼辦法呢?但是,這個 Model 有時無法滿足我們的一些需求,因此我們需要自訂一個 Model 類出來,不過自訂的 Model 同樣要繼承 TP 提供的 Model 類,而把我們自訂的 Model 類作為我們項目中的 Model 基類。我怎麼感覺我在說繞口令,等等...我有點暈。
無聊的需求
在使用 Java 的開源項目 JeeSite 時,養成了一個不好的習慣,習慣給每張表都增加 create_by、create_date、update_by、update_date、remarks 和 del_flag 這麼幾個欄位。如果每張表都有這幾個欄位,那麼對每張表進行 insert 時都會對以上的欄位進行設定,對每張表進行 update 時都會對其中部分欄位進行更新,對每條記錄進行 delete 時都其實是對 del_flag 欄位進行 置位。重複操作很多,一些操作方法被修改。那麼,這個時候就要自訂一個自己的 Model 來作為項目的 基類 了,這個 Model 就負責幹上面我說的那些事情了。
自訂一個 Model
自訂一個 Model,Model 中至少重新 TP 提供的 Model 中的 add、save、delete 和 select 方法。
定義代碼如下:
<?phpnamespace Admin\Model;use Think\Model;/** * 項目中其他 Model 類的基類 * 該類繼承自 TP 提供的基類 Model */class BaseModel extends Model { /** * 繼承基類 Model 的 add 方法 * 自動插入 id create_by create_date update_by update_date del_flag */ public function add($data='',$options=array(),$replace=false) { $data["id"] = $this->getUuid(); $data["create_by"] = ""; $data["create_date"] = date("Y-m-d H:i:s"); $data["update_by"] = ""; $data["update_date"] = date("Y-m-d H:i:s"); $data["del_flag"] = '0'; return parent::add($data, $options, $replace); } /** * 獲得 未刪除 的所有資料 * 記錄是否被刪除通過 del_flag 欄位來進行確定 */ public function select($options=array()) { $map["del_flag"] = 0; $this->where($map); return parent::select($options); } /** * 擷取 全部 的所有資料 */ public function selectAll($options=array()) { return parent::select($options); } /** * 更新資料 * 更新資料時,要更新 update_by update_date 兩個欄位 */ public function save($data='',$options=array()) { $data["update_by"] = ""; $data["update_date"] = date("Y-m-d H:i:s"); return parent::save($data, $options); } /** * 刪除也是更新 * 設定 刪除 標誌位即可 */ public function delete($data='',$options=array()) { $data["del_flag"] = 1; return parent::save($data, $options); }
這樣,我們的 BaseModel 就定義好了,以後項目中的 Model 就不再繼承 TP 的 Model 類了,而是繼承我們自訂的 BaseModel 了。
繼承我們定義的基類
繼承的 BaseModel 的方法和繼承 Model 的方法是一樣的,只是使用 use 引入命名空間到當前範圍時的需要修改為我們的命名空間,而不是再去使用 TP 提供的命名空間。代碼如下:
1 <?php2 namespace Admin\Model;3 use Admin\Model\BaseModel;4 5 class TrunkModel extends BaseModel {
use 引入的命名空間是 Admin\Model\BaseModel ,因為我們定義的 BaseModel 的命名空間是 Admin\Model,因為這裡的 TrunkModel 和 BaseModel 在一個命名空間下,省去 use 也是可以的。
這樣,在我們用 D 方法執行個體化 TrunkModel 的對象後,使用 add 方法插入資料時,就會先調用 BaseModel 中的 add 方法了,這樣我們每張表都有的 create_by 等一數列欄位就都會自動得到了。