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