本篇內(nèi)容主要講解“如何理解Laravle eloquent多對多模型關(guān)聯(lián)”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“如何理解Laravle eloquent多對多模型關(guān)聯(lián)”吧!
創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站設(shè)計、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的岳池網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!什么是多對多關(guān)聯(lián)?
Eloquent中一個模型就是一個數(shù)據(jù)表,數(shù)據(jù)表之間通常會有關(guān)聯(lián),多對多關(guān)聯(lián)就是2個表之間相互有很多關(guān)聯(lián),比如說:一個表存放了用戶數(shù)據(jù),
另一個表存放了文章的信息,
一個用戶可以收藏多篇文章,一篇文章也可以被多個用戶收藏,這就是 多對多關(guān)聯(lián) 。
怎么用多對多關(guān)聯(lián)?
使用Eloquent的多對多關(guān)聯(lián)可以很便捷的互相查詢、修改、增加、刪除兩個模型之間的關(guān)聯(lián)。
多對多關(guān)聯(lián)除了相互關(guān)聯(lián)的兩張表之外還需要一張記錄關(guān)聯(lián)的表(pivot表),一般記錄兩個模型的的ID就行
舉個栗子
我們數(shù)據(jù)庫里的三張表是user
articles
article_collections
我們需要創(chuàng)建2個模型,中間表模型不是必須的
通過在模型里寫一個方法調(diào)用belongToMany()方法并返回結(jié)果來獲取數(shù)據(jù)。
belongToMany()里傳入的第一個參數(shù)是對應(yīng)表,第二個參數(shù)是中間表的表名,第三個參數(shù)是當(dāng)前模型在中間表的鍵名,第四個參數(shù)是關(guān)聯(lián)模型在中間表的鍵名。
belongToMany(Articles::class, 'article_collections', 'user_id', 'article_id') } }這樣我們就可以通過article方法得到user收藏的文章了
$articles = User::find(1)->articles()->get();用where()、orderBy()等方法對查詢的數(shù)據(jù)添加條件
用attach()方法添加關(guān)聯(lián),比如讓id為1用戶收藏id為1的article
$user = User::find(1); $user->articles()->attach(1)用detach()方法去除關(guān)聯(lián),方法和attach()一樣。
OK 以上就是Laravel eloquent 多對多關(guān)聯(lián)的一些基礎(chǔ)知識了。
到此,相信大家對“如何理解Laravle eloquent多對多模型關(guān)聯(lián)”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)建站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
當(dāng)前名稱:如何理解Laravleeloquent多對多模型關(guān)聯(lián)-創(chuàng)新互聯(lián)
文章URL:http://weahome.cn/article/ddjecc.html