以前写过关于模型关联的笔记,可是模型关联好后的一些使用没有介绍,今天补上数组
咱们准备了两个模型:Post和Comment。 它们的关系是一对多关系。如今咱们要建立新的Comment到Post:post
public function getIndex() { // 建立一个comment模型 $comment = new Comment(['title'=> 'comment1', 'content'=> 'content1']); // 取到post模型 $post = Post::findOrFail(1); $post->comments()->save($comment); }
这样建立呢 Comment的post_id 列会自动填充。spa
咱们还能够批量的添加下属模型,至关方便~:code
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]); }
准备一个Tag模型,它和Post模型是多对多的关系,别忘了生成中间表哦:blog
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会自动为咱们填充中间表的关联属性,ip
多对多的save方法中是容许咱们传入第二个参数的。第二个参数是中间表的属性数组:ci
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]); }
Create方法是一种批量填充模式 因此记得在Model中设置白/黑名单,它和save的惟一区别就是 只能传递数组、不能将一个模型实例传入。get
public function getIndex() { $tag = Tag::findOrFail(1); // create方法一样也能够接受第二个参数。 $tag->posts()->create([ 'title' => 'Laravel Model', 'sub_title' => 'Laravel 模型关联的使用', 'content' => 'content...' ], ['expires' => true]); }
重要的事情须要重复一遍:associate方法只不对多对多关系适用。并且使用时要用下方模型 调用associate方法,将下方模型更新到新的上方模型。同步
public function getIndex() { $post = Post::findOrFail(1); $comment = Comment::findOrFail(1); $comment->post()->associate($post); $comment->save(); }
重要的事情须要重复一遍:dissociate方法只不对多对多关系适用。并且使用时要用下方模型 调用dissociate方法,将下方模型从上方模型的关联中移除。此外此方法执行后会将下方模型的外键id至为0。it
public function getIndex() { $post = Post::findOrFail(1); $comment = Comment::findOrFail(1); $comment->post()->dissociate($post); $comment->save(); }
必定要看注释,必定要看注释,必定要看注释,注释解释的很清楚,你可能心中有疑问 这个追加关系和之间建立关系有什么区别?你可能忽视了一个细节:建立添加时 是新建一个模型后加入关联,而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(整型)便可,中间表会自动更新。 // 注意:attach的功能是追加一个关系并不是更新,执行如下代码后 该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]); }
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]); }
同步关系可谓是很是方便,具体的看注释吧,写的很清楚:
public function getIndex() { // 取出id为2的tag,此时它只和id为3的post有关联。 $tag = Tag::findOrFail(2); // 同步:传入一个id数组,存在于此数组的id都会被追加关系,而不在此数组中的id模型关联 都会被移除。 $tag->posts()->sync([2, 4, 5]); }
注意:sync方法也能够传入第二个参数,也是数组类型 以便更新中间表中的其余列。因为语法跟前面几个方法同样,就不在重复写了。