Laravel怎么写入关联模型及更新关联关系
Admin 2022-05-31 群英技术资讯 1421 次浏览
这篇文章主要讲解了“Laravel怎么写入关联模型及更新关联关系”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Laravel怎么写入关联模型及更新关联关系”吧!本文实例讲述了Laravel5.1 框架关联模型之后操作。分享给大家供大家参考,具体如下:
我们准备了两个模型: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]);
}
准备一个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]);
}
Create方法是一种批量填充模式 所以记得在Model中设置白/黑名单,它和save的唯一区别就是 只能传递数组、不能将一个模型实例传入。
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。
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方法也可以传入第二个参数,也是数组类型 以便更新中间表中的其他列。由于语法跟前面几个方法一样,就不在重复写了。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
在本篇文章里小编给大家分享了关于PHP strripos函数用法知识点,有兴趣的朋友们学习下。
php框架的底层原理:1、PHP实现了典型的动态语言执行过程。2、底层原理分析,Zend整体是纯c实现的,是PHP的核心部分,将PHP代码翻译,实现opcode的处理。
PHP的Snoopy类功能是什么,怎样使用?有不少朋友对此感兴趣,下面小编给大家整理和分享了相关知识和资料,易于大家学习和理解,有需要的朋友可以借鉴参考,下面我们一起来了解一下吧。
在Apache中整合JSP和PHP 我们最希望任何事都是完美的,如在企业应用中,我们只需要选择一个Web平台就可以部署所有的企业应用。但往往理想与现实相去甚远。在现实世界中,信息系统往往是由很多不同的操作系统、平台以及应用环境混合而成的。而且为了保持与旧的系统兼容,系统总是将当前的技术和以前的遗留技术进行混合,这样周而复始。就使系统变得越来越复杂。 对于这样的恶性变化会使
今天小编就为大家分享一篇关于在PHP中输出JS语句以及乱码问题的解决方案,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008