2023-11-01 分類: 網站建設
用cmd指令在文件根目錄下創建模型php think make:model 模塊/模型名稱
模型會創建在application目錄下的 “模塊\模型[模型名稱]” 中。
2.模型命名
模型類的命名規則是除去表前綴的數據表名稱,采用駝峰法命名,并且首字母大寫,比如表的表前綴是 db_
在模型名稱里就需要省略掉。所以 db_admin
表的模型類名就是 Admin
, db_admin_message
的模型類名就是AdminMessage
3.一對一關聯
hasOne (‘關聯模型名’,‘關聯外鍵’,‘主鍵’,‘別名定義’, ‘join類型’)
關聯操作都是基于(第一)模型的話,(第二)模型中并不需要定義關聯方法,使用belongsTo 方法就可以。
belongsTo 方法和 hasOne 一樣,也有5個參數:
belongsTo(‘關聯模型名’,‘關聯外鍵’,‘關聯模型主鍵’,‘別名定義’,‘join類型’)
a.模型定義
// 定義關聯方法,在User模型哄下定義 public function profile(){ //HASONE關聯 return $this->hasOne('profile','id', 'id'); }
在User模型定義好關聯的方法之后在profile模型里可以不用寫任何對應的方法,但是必須最少要有一個對應db_profile 表的空模型。
b.倘若關聯操作都基于profile方法時,在profile模型下定義
public function user(){ //檔案bELONGSTO關聯操作都基于profile方法時,直接使用 return $this->belongsTo('User'); }
c.控制器調用
public function index($name='name'){ //get 1 是獲取id為 1 的數據 //find() 是查找 //toArray() 是獲取到的數據轉為數組 $admin= Admin::get(1); //查巡當前Admin模型數據 var_dump($admin->find()->toArray()); //查巡關聯模型AdminMessage模型數據 $admin= $admin->AdminMessage->find()->toArray(); }
d.輸出結果:
hasMany(‘關聯模型名’,‘關聯外鍵’,‘關聯模型主鍵’,‘別名定義’)
a.模型調用
public function books(){ return $this->hasMany('book','id','id'); }
b.控制器調用
關聯添加:也可以批量增加數據
關聯查詢:可以直接調用模型的屬性獲取全部關聯數據
public function read(){ $user = UserModel::get(1); // 獲取狀態為1的關聯數據 $books = $user->books()->where('status',1)->select(); dump($books); // 獲取作者寫的某本書 $book = $user->books()->getbyTitle('ThinkpHp5快速入門'); dump($book); }
關聯更新:
public function update($id){ $user = UserModel::get($id); $book = $user->books()->getbyTitle('ThinkpHp5開發手冊'); $book->title = 'ThinkpHp5快速入門'; $book->save(); }
關聯刪除:
//刪除部分關聯數據: $book = $user->books()->getbyTitle('ThinkpHp5開發手冊'); $book->delete(); //刪除所有的關聯數據: if($user->delete()){ // 刪除所有的關聯數據 $user->books()->delete(); }
一個用戶會有多個角色,同時一個角色也會包含多個用戶,這就是一個典型的多對多關聯
多對多關聯通常一定會有一個中間表,也稱為樞紐表,所以需要創建一個用戶角色的中間表
belongsToMany 的參數如下
belongsToMany(‘關聯模型名’,‘中間表名稱’,‘關聯外鍵’,‘關聯模型主鍵’,‘別名定義’)
對于樞紐表并不需要創建模型類,在多對多關聯關系中,并不需要直接操作樞紐表。
a.模型定義
// 定義多對多關聯 public function roles(){ // 用戶 bELONGS_TO_MANY 角色 return $this->belongsToMany('Role', 'think_access'); }
關聯新增
新增用戶角色 并自動寫入樞紐表$user->roles()->save(['name' => 'editor', 'title' => '編輯']);
批量新增
$user->roles()->saveAll([ ['name' => 'leader', 'title' => '領導'], ['name' => 'admin', 'title' => '管理員'], ]);
由于該角色已經存在了,所以只需要使用attach 方法增加樞紐表的關聯數據:
$user->roles()->attach($role);
關聯刪除
使用detach 方法刪除關聯的樞紐表數據,但不會刪除關聯模型數據
$user->roles()->detach($role);
刪除樞紐表的同時刪除關聯模型
$user->roles()->detach($role,true);
輸出數組: toArray 方法把模型對象輸出為數組。
$user->toArray()
隱藏屬性:hidden方法在輸出的時候隱藏某些屬性
模型名->方法([字段名稱,字段名稱,***]) $user->hidden(['create_time','update_time'])->toArray()
指定屬性:visible方法指定一些屬性輸出
模型名->方法([字段名稱,字段名稱,***])
$user->visible(['id','nickname','email'])->toArray()
追加屬性
如果讀取器定義了一些非數據庫字段的讀取,例如:
class User extends Model{ // status修改器 protected function getUserStatusAttr($value){ $status = [-1 => '刪除', 0 => '禁用', 1 => '正常', 2 => '待審核']; return $status[$value]; &n新聞標題:THINKpHp5的基本模型關聯
文章網址:http://vcdvsql.cn/news30/291880.html成都網站建設公司_創新互聯,為您提供網站策劃、移動網站建設、服務器托管、動態網站、用戶體驗、關鍵詞優化
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯
猜你還喜歡下面的內容