THINKpHp5的基本模型關(guān)聯(lián)

2023-11-01    分類: 網(wǎng)站建設(shè)

1.創(chuàng)建thinkpHp模型

用cmd指令在文件根目錄下創(chuàng)建模型
php think make:model 模塊/模型名稱

模型會(huì)創(chuàng)建在application目錄下的 “模塊\模型[模型名稱]” 中。

2.模型命名

模型類的命名規(guī)則是除去表前綴的數(shù)據(jù)表名稱,采用駝峰法命名,并且首字母大寫(xiě),比如表的表前綴是 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模型里可以不用寫(xiě)任何對(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é)果:

4.一對(duì)多關(guān)聯(lián)

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);       // 獲取作者寫(xiě)的某本書(shū)       $book = $user->books()->getbyTitle('ThinkpHp5快速入門');       dump($book);    }

  • 關(guān)聯(lián)更新:

    public function update($id){    $user = UserModel::get($id);    $book = $user->books()->getbyTitle('ThinkpHp5開(kāi)發(fā)手冊(cè)');    $book->title = 'ThinkpHp5快速入門';    $book->save();    }

  • 關(guān)聯(lián)刪除:

    //刪除部分關(guān)聯(lián)數(shù)據(jù):    $book = $user->books()->getbyTitle('ThinkpHp5開(kāi)發(fā)手冊(cè)');    $book->delete();    //刪除所有的關(guān)聯(lián)數(shù)據(jù):    if($user->delete()){    // 刪除所有的關(guān)聯(lián)數(shù)據(jù)    $user->books()->delete();    }

5.多對(duì)多關(guān)聯(lián)

一個(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)寫(xiě)入樞紐表
    $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);

6.模型輸出

  • 輸出數(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://www.muchs.cn/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)

成都網(wǎng)站建設(shè)公司