Laravel5.1 框架關(guān)聯(lián)模型之后操作實(shí)例分析
本文實(shí)例講述了Laravel5.1 框架關(guān)聯(lián)模型之后操作。分享給大家供大家參考,具體如下:
之前寫過關(guān)于模型關(guān)聯(lián)的筆記,但是模型關(guān)聯(lián)好后的一些使用沒有介紹,今天補(bǔ)上
1 寫入關(guān)聯(lián)模型
1.1 使用Save方法(一對(duì)多)
我們準(zhǔn)備了兩個(gè)模型:Post和Comment。 它們的關(guān)系是一對(duì)多關(guān)系?,F(xiàn)在我們要?jiǎng)?chuàng)建新的Comment到Post:
public function getIndex() { // 創(chuàng)建一個(gè)comment模型 $comment = new Comment(['title'=> 'comment1', 'content'=> 'content1']); // 取到post模型 $post = Post::findOrFail(1); $post->comments()->save($comment); }
這樣創(chuàng)建呢 Comment的post_id 列會(huì)自動(dòng)填充。
我們還可以批量的添加下屬模型,相當(dāng)方便~:
public function getIndex() { // 創(chuàng)建一個(gè)comment模型 $comment2 = new Comment(['title'=> 'comment2', 'content'=> 'content2']); $comment3 = new Comment(['title'=> 'comment3', 'content'=> 'content3']); // 取到post模型 $post = Post::findOrFail(1); $post->comments()->saveMany([$comment2, $comment3]); }
1.2 使用Save方法(多對(duì)多)
準(zhǔn)備一個(gè)Tag模型,它和Post模型是多對(duì)多的關(guān)系,別忘了生成中間表哦:
public function getIndex() { // 創(chuàng)建文章 $post = new Post(); $post->title = 'Laravel Model'; $post->sub_title = '模型的詳細(xì)使用'; $post->content = 'content...'; // 添加到Tag $tag = Tag::findOrFail(1); $tag->posts()->save($post); }
↑ 我們無需管中間表,Laravel會(huì)自動(dòng)為我們填充中間表的關(guān)聯(lián)屬性,
多對(duì)多的save方法中是允許我們傳入第二個(gè)參數(shù)的。第二個(gè)參數(shù)是中間表的屬性數(shù)組:
public function getIndex() { // 創(chuàng)建文章 $post = new Post(); $post->title = 'Laravel Model'; $post->sub_title = '模型的詳細(xì)使用'; $post->content = 'content...'; // 添加到Tag $tag = Tag::findOrFail(1); // 當(dāng)創(chuàng)建時(shí)需要填充中間表的額外列時(shí),可以傳遞第二個(gè)參數(shù)。 // 這里我們的中間表有個(gè)expires列,添加關(guān)聯(lián)時(shí)可以同時(shí)設(shè)置。 $tag->posts()->save($post, ['expires' => true]); }
1.3 使用Create方法
Create方法是一種批量填充模式 所以記得在Model中設(shè)置白/黑名單,它和save的唯一區(qū)別就是 只能傳遞數(shù)組、不能將一個(gè)模型實(shí)例傳入。
public function getIndex() { $tag = Tag::findOrFail(1); // create方法同樣也可以接受第二個(gè)參數(shù)。 $tag->posts()->create([ 'title' => 'Laravel Model', 'sub_title' => 'Laravel 模型關(guān)聯(lián)的使用', 'content' => 'content...' ], ['expires' => true]); }
2 更新關(guān)聯(lián)關(guān)系
2.1 更新一個(gè)關(guān)系(除多對(duì)多適用)
重要的事情需要重復(fù)一遍:associate方法只不對(duì)多對(duì)多關(guān)系適用。而且使用時(shí)要用下方模型 調(diào)用associate方法,將下方模型更新到新的上方模型。
public function getIndex() { $post = Post::findOrFail(1); $comment = Comment::findOrFail(1); $comment->post()->associate($post); $comment->save(); }
2.2 移除一個(gè)關(guān)系(除多對(duì)多適用)
重要的事情需要重復(fù)一遍:dissociate方法只不對(duì)多對(duì)多關(guān)系適用。而且使用時(shí)要用下方模型 調(diào)用dissociate方法,將下方模型從上方模型的關(guān)聯(lián)中移除。此外此方法執(zhí)行后會(huì)將下方模型的外鍵id至為0。
public function getIndex() { $post = Post::findOrFail(1); $comment = Comment::findOrFail(1); $comment->post()->dissociate($post); $comment->save(); }
2.3 追加一個(gè)關(guān)系(多對(duì)多關(guān)系)
一定要看注釋,一定要看注釋,一定要看注釋,注釋解釋的很清楚,你可能心中有疑問 這個(gè)追加關(guān)系和之間創(chuàng)建關(guān)系有什么區(qū)別?你可能忽視了一個(gè)細(xì)節(jié):創(chuàng)建添加時(shí) 是新建一個(gè)模型后加入關(guān)聯(lián),而attach方法是:追加一個(gè)已經(jīng)存在的模型進(jìn)行關(guān)聯(lián)。
public function getIndex() { // 取到ID為3的文章 這篇文章與id為1的tag有關(guān)系。 $post = Post::findOrFail(3); // attach方法的參數(shù)只需要傳遞id(整型)即可,中間表會(huì)自動(dòng)更新。 // 注意:attach的功能是追加一個(gè)關(guān)系并非更新,執(zhí)行以下代碼后 該post會(huì)與id為3和2的tag有關(guān)系。 $post->tags()->attach(2); $post->save(); }
當(dāng)追加關(guān)系時(shí)同樣也可以將一個(gè)中間表數(shù)據(jù)加入第二個(gè)參數(shù),以此更新中間表的其他列。
public function getIndex() { // 取到ID為3的文章 這篇文章與id為1的tag有關(guān)系。 $post = Post::findOrFail(3); // attach方法的參數(shù)只需要傳遞id(整型)即可,中間表會(huì)自動(dòng)更新。 // 注意:attach的功能是追加一個(gè)關(guān)系并非更新,執(zhí)行以下代碼后 該post會(huì)與id為3和2的tag有關(guān)系。 $post->tags()->attach(2, ['expires' => true]); }
批量追加:
public function getIndex() { $post = Post::findOrFail(3); // 第一個(gè)參數(shù)也可以接收一個(gè)數(shù)組。 $post->tags()->attach([2, ['expires' => true], 4, 6]); }
2.4 卸載一個(gè)關(guān)系(多對(duì)多關(guān)系)
detach方法于attach方法相反,detach方法會(huì)將關(guān)聯(lián)關(guān)系刪除:
public function getIndex() { $post = Post::findOrFail(3); $post->tags()->detach(1); }
批量卸載:
public function getIndex() { $post = Post::findOrFail(3); $post->tags()->detach([1, 3, 5]); }
2.5 同步關(guān)系
同步關(guān)系可謂是非常方便,具體的看注釋吧,寫的很清楚:
public function getIndex() { // 取出id為2的tag,此時(shí)它只和id為3的post有關(guān)聯(lián)。 $tag = Tag::findOrFail(2); // 同步:傳入一個(gè)id數(shù)組,存在于此數(shù)組的id都會(huì)被追加關(guān)系,而不在此數(shù)組中的id模型關(guān)聯(lián) 都會(huì)被移除。 $tag->posts()->sync([2, 4, 5]); }
注意:sync方法也可以傳入第二個(gè)參數(shù),也是數(shù)組類型 以便更新中間表中的其他列。由于語法跟前面幾個(gè)方法一樣,就不在重復(fù)寫了。
更多關(guān)于Laravel相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Laravel框架入門與進(jìn)階教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對(duì)大家基于Laravel框架的PHP程序設(shè)計(jì)有所幫助。
- 在laravel中實(shí)現(xiàn)ORM模型使用第二個(gè)數(shù)據(jù)庫設(shè)置
- 使用laravel的Eloquent模型如何獲取數(shù)據(jù)庫的指定列
- Laravel5.1 框架模型多態(tài)關(guān)聯(lián)用法實(shí)例分析
- Laravel5.1 框架模型遠(yuǎn)層一對(duì)多關(guān)系實(shí)例分析
- Laravel5.1 框架模型一對(duì)一關(guān)系實(shí)現(xiàn)與使用方法實(shí)例分析
- Laravel5.1 框架模型查詢作用域定義與用法實(shí)例分析
- Laravel5.1 框架模型軟刪除操作實(shí)例分析
- Laravel5.1 框架模型創(chuàng)建與使用方法實(shí)例分析
- Laravel框架視圖和模型操作方法分析
- Laravel 5框架學(xué)習(xí)之模型、控制器、視圖基礎(chǔ)流程
- laravel學(xué)習(xí)教程之關(guān)聯(lián)模型
- laravel框架模型和數(shù)據(jù)庫基礎(chǔ)操作實(shí)例詳解
相關(guān)文章
php中重定向網(wǎng)頁跳轉(zhuǎn)方法總結(jié)案例教程
這篇文章主要介紹了php中重定向網(wǎng)頁跳轉(zhuǎn)方法總結(jié)案例教程,本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08php 計(jì)算兩個(gè)時(shí)間相差的天數(shù)、小時(shí)數(shù)、分鐘數(shù)、秒數(shù)詳解及實(shí)例代碼
這篇文章主要介紹了php 計(jì)算兩個(gè)時(shí)間相差的天數(shù)、小時(shí)數(shù)、分鐘數(shù)、秒數(shù)詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2016-11-11ThinkPHP3.2.3實(shí)現(xiàn)分頁的方法詳解
這篇文章主要介紹了ThinkPHP3.2.3實(shí)現(xiàn)分頁的方法,詳細(xì)分析了thinkPHP3.2.3分頁操作的相關(guān)技巧,包括分頁類的引用、數(shù)據(jù)庫查詢操作、分頁參數(shù)設(shè)置及前端視圖界面設(shè)計(jì)等,需要的朋友可以參考下2016-06-06PHP的openssl加密擴(kuò)展使用小結(jié)(推薦)
下面小編就為大家?guī)硪黄狿HP的openssl加密擴(kuò)展使用小結(jié)(推薦)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-07-07Codeigniter實(shí)現(xiàn)處理用戶登錄驗(yàn)證后的URL跳轉(zhuǎn)
這篇文章主要介紹了Codeigniter實(shí)現(xiàn)處理用戶登錄驗(yàn)證后的URL跳轉(zhuǎn),需要的朋友可以參考下2014-06-06Yii框架中 find findAll 查找出制定的字段的方法對(duì)比
在yii框架中可以使用映射類的find方法取出一條數(shù)據(jù)或者用findall方法取出數(shù)條數(shù)據(jù)來,那么如何按照所需條件來取數(shù)據(jù)呢,主要用到了CDbCriteria這個(gè)類,這個(gè)類是yii自帶的操作數(shù)據(jù)庫的支持類2014-09-09