Laravel5.1 框架關聯模型之後操作例項分析
本文例項講述了Laravel5.1 框架關聯模型之後操作。分享給大家供大家參考,具體如下:
之前寫過關於模型關聯的筆記,但是模型關聯好後的一些使用沒有介紹,今天補上
1 寫入關聯模型
1.1 使用Save方法(一對多)
我們準備了兩個模型:Post和Comment。 它們的關係是一對多關係。現在我們要建立新的Comment到Post:
public function getIndex() { // 建立一個comment模型 $comment = new Comment(['title'=> 'comment1','content'=> 'content1']); // 取到post模型 $post = Post::findOrFail(1); $post->comments()->save($comment); }
這樣建立呢 Comment的post_id 列會自動填充。
我們還可以批量的新增下屬模型,相當方便~:
public function getIndex() { // 建立一個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方法(多對多)
準備一個Tag模型,它和Post模型是多對多的關係,別忘了生成中間表哦:
public function getIndex() { // 建立文章 $post = new Post(); $post->title = 'Laravel Model'; $post->sub_title = '模型的詳細使用'; $post->content = 'content...'; // 新增到Tag $tag = Tag::findOrFail(1); $tag->posts()->save($post); }
↑ 我們無需管中間表,Laravel會自動為我們填充中間表的關聯屬性,
多對多的save方法中是允許我們傳入第二個引數的。第二個引數是中間表的屬性陣列:
public function getIndex() { // 建立文章 $post = new Post(); $post->title = 'Laravel Model'; $post->sub_title = '模型的詳細使用'; $post->content = 'content...'; // 新增到Tag $tag = Tag::findOrFail(1); // 當建立時需要填充中間表的額外列時,可以傳遞第二個引數。 // 這裡我們的中間表有個expires列,新增關聯時可以同時設定。 $tag->posts()->save($post,['expires' => true]); }
1.3 使用Create方法
Create方法是一種批量填充模式 所以記得在Model中設定白/黑名單,它和save的唯一區別就是 只能傳遞陣列、不能將一個模型例項傳入。
public function getIndex() { $tag = Tag::findOrFail(1); // create方法同樣也可以接受第二個引數。 $tag->posts()->create([ 'title' => 'Laravel Model','sub_title' => 'Laravel 模型關聯的使用','content' => 'content...' ],['expires' => true]); }
2 更新關聯關係
2.1 更新一個關係(除多對多適用)
重要的事情需要重複一遍:associate方法只不對多對多關係適用。而且使用時要用下方模型 呼叫associate方法,將下方模型更新到新的上方模型。
public function getIndex() { $post = Post::findOrFail(1); $comment = Comment::findOrFail(1); $comment->post()->associate($post); $comment->save(); }
2.2 移除一個關係(除多對多適用)
重要的事情需要重複一遍:dissociate方法只不對多對多關係適用。而且使用時要用下方模型 呼叫dissociate方法,將下方模型從上方模型的關聯中移除。此外此方法執行後會將下方模型的外來鍵id至為0。
public function getIndex() { $post = Post::findOrFail(1); $comment = Comment::findOrFail(1); $comment->post()->dissociate($post); $comment->save(); }
2.3 追加一個關係(多對多關係)
一定要看註釋,一定要看註釋,一定要看註釋,註釋解釋的很清楚,你可能心中有疑問 這個追加關係和之間建立關係有什麼區別?你可能忽視了一個細節:建立新增時 是新建一個模型後加入關聯,而attach方法是:追加一個已經存在的模型進行關聯。
public function getIndex() { // 取到ID為3的文章 這篇文章與id為1的tag有關係。 $post = Post::findOrFail(3); // attach方法的引數只需要傳遞id(整型)即可,中間表會自動更新。 // 注意:attach的功能是追加一個關係並非更新,執行以下程式碼後 該post會與id為3和2的tag有關係。 $post->tags()->attach(2); $post->save(); }
當追加關係時同樣也可以將一箇中間表資料加入第二個引數,以此更新中間表的其他列。
public function getIndex() { // 取到ID為3的文章 這篇文章與id為1的tag有關係。 $post = Post::findOrFail(3); // attach方法的引數只需要傳遞id(整型)即可,執行以下程式碼後 該post會與id為3和2的tag有關係。 $post->tags()->attach(2,['expires' => true]); }
批量追加:
public function getIndex() { $post = Post::findOrFail(3); // 第一個引數也可以接收一個數組。 $post->tags()->attach([2,['expires' => true],4,6]); }
2.4 解除安裝一個關係(多對多關係)
detach方法於attach方法相反,detach方法會將關聯關係刪除:
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 同步關係
同步關係可謂是非常方便,具體的看註釋吧,寫的很清楚:
public function getIndex() { // 取出id為2的tag,此時它只和id為3的post有關聯。 $tag = Tag::findOrFail(2); // 同步:傳入一個id陣列,存在於此陣列的id都會被追加關係,而不在此陣列中的id模型關聯 都會被移除。 $tag->posts()->sync([2,5]); }
注意:sync方法也可以傳入第二個引數,也是陣列型別 以便更新中間表中的其他列。由於語法跟前面幾個方法一樣,就不在重複寫了。
更多關於Laravel相關內容感興趣的讀者可檢視本站專題:《Laravel框架入門與進階教程》、《php優秀開發框架總結》、《php面向物件程式設計入門教程》、《php+mysql資料庫操作入門教程》及《php常見資料庫操作技巧彙總》
希望本文所述對大家基於Laravel框架的PHP程式設計有所幫助。