之前写过关于模型关联的笔记,但是模型关联好后的一些使用没有介绍,今天补上


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(整型)即可,中间表会自动更新。
// 注意: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]);
}

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, 4, 5]);
}

注意:sync方法也可以传入第二个参数,也是数组类型 以便更新中间表中的其他列。由于语法跟前面几个方法一样,就不在重复写了。

Laravel5.1 关联模型之后操作的更多相关文章

  1. laravel5.1 关联模型保存的方法(使用associate方法)

    模型定义 class User { public function customer() { return $this->hasOne('Customer'); } } class Custom ...

  2. laravel5.6 ORM 关联模型,一对一和一对多

    Laravel5.6 关联模型的操作,主要是一对一,一对多,多对多等操作.下面示例主要解析前面两个操作用法比较常用.(操作和用法TP5类似)将关联查询使用语法hasOne.hasMany.belong ...

  3. ThinkPHP 学习笔记 ( 四 ) 数据库操作之关联模型 ( RelationMondel ) 和高级模型 ( AdvModel )

    一.关联模型 ( RelationMondel ) 1.数据查询 ① HAS_ONE 查询 创建两张数据表评论表和文章表: tpk_comment , tpk_article .评论和文章的对应关系为 ...

  4. ThinkPHP 3.2.3 关联模型的使用

    关于关联模型 ThinkPHP 3.2.3 的关联模型(手册地址)一般处理关联数据表的 CURD 操作,例如关联读取.关联写入.关联删除等. 实例 博客管理模块关于博客有 4 张数据表:博客表 crm ...

  5. ThinkPHP第十五天(setField、setInc、setDec、关联模型)

    1.ThinkPHP中的比较特殊连贯操作 如果要更新某个字段可以用setField方法,比如M('user')->where('id=1')->setField('username','T ...

  6. Django学习笔记之数据库-模型的操作

    模型的操作 在ORM框架中,所有模型相关的操作,比如添加/删除等.其实都是映射到数据库中一条数据的操作.因此模型操作也就是数据库表中数据的操作. 添加模型 添加模型到数据库中.首先需要创建一个模型.创 ...

  7. <记录>TP5 关联模型使用(嵌套关联、动态排序以及隐藏字段)

    在数据库设计中,常常会有如下这种关联模型,分类表中一条分类对应多个商品表中的商品 如果要获得分类表中每条分类 以及 对应的商品的信息,则需要先查询分类表中的数据,然后根据结果遍历查询商品表,最后把数据 ...

  8. Thinkphp 关联模型和试图模型区别

    关联模型主要在多表操作时使用,比如 user表,user_role表,role表 user_role字段:uid,rid,它作为中间表,负责将user和role之间的,1对1,1对多,多对多的关系进行 ...

  9. TP5 关联模型使用(嵌套关联、动态排序以及隐藏字段)

    在数据库设计中,常常会有如下这种关联模型,分类表中一条分类对应多个商品表中的商品 如果要获得分类表中每条分类 以及 对应的商品的信息,则需要先查询分类表中的数据,然后根据结果遍历查询商品表,最后把数据 ...

随机推荐

  1. 转:Socket常用选项

    功能描述 获取或者设置与某个套接字关联的选 项.选项可能存在于多层协议中,它们总会出现在最上面的套接字层.当操作套接字选项时,选项位于的层和选项的名称必须给出.为了操作套接字层的选项,应该 将层的值指 ...

  2. 转:sock_ev——linux平台socket事件框架(logTrace) .

    写代码要有调试log,采用syslog的输出:一般会输出到"/var/log/messages" /**************************************** ...

  3. android下载

    1. 源码下载链接: http://source.android.com/source/downloading.html 参考链接: Android源码下载方法详解 2. SDK下载 http://d ...

  4. jquery api 常见api 效果操作例子

    addClass_removeClass_toggleClass_hasClass.html <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 ...

  5. laravel使用的模板引擎 blade

    使用blade引擎的话必须在控制器中使用use   Blade

  6. [Asp.Net]最近一个项目的总结

    引言 项目到目前告一段落,目前进入测试阶段,下周就要去部署了.虽然项目不大,但是从头到尾都是自己一个人负责,在完成编码之后,对代码进行走查,命名规范,业务逻辑,代码优化等,能负责一个项目的整个编码,非 ...

  7. ASP.NET MVC之Html.RenderAction(无操作方法 传参数)

    WEB窗体模式开发惯了,切入MVC模式,好多东西都不懂,每一步都要查资料. 初步得来的一些知识点体会是: _Layout.cshtml就相当于母版页 然后partical视图(部分视图)就是用户控件. ...

  8. baidu经纬度坐标与google经纬度坐标都转换

    baidu经纬度坐标与google经纬度坐标都是经过转换的.使用下面那个url可以将原始坐标或者谷歌的坐标转换成baidu的坐标http://api.map.baidu.com/ag/coord/co ...

  9. PostgreSQL在线安装

    背景:CentOS 7 一.在线yum安装 yum -y install https://download.postgresql.org/pub/repos/yum/9.5/redhat/rhel-7 ...

  10. hibernate中继承映射保存

    1 简单继承映射,在子类上进行映射配置,可以将父类属性直接配置在子类映射文件中. 简单例子如下:teacher类继承自Person类. public class Person { private in ...