本文实例讲述了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(整型)即可,中间表会自动更新。
    // 注意: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方法也可以传入第二个参数,也是数组类型 以便更新中间表中的其他列。由于语法跟前面几个方法一样,就不在重复写了。

更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。

Laravel5.1 框架关联模型之后操作实例分析的更多相关文章

  1. Laravel5.1 框架文件管理操作实例分析

    这篇文章主要介绍了Laravel5.1 框架文件管理操作,结合实例形式分析了laravel5.1框架文件管理相关的配置、磁盘获取以及文件目录操作技巧,需要的朋友可以参考下

  2. Laravel5.1 框架模型创建与使用方法实例分析

    这篇文章主要介绍了Laravel5.1 框架模型创建与使用方法,结合实例形式分析了laravel5.1框架模型的原理、创建、更新、获取等相关操作技巧,需要的朋友可以参考下

  3. Laravel5.1 框架Request请求操作常见用法实例分析

    这篇文章主要介绍了Laravel5.1 框架Request请求操作常见用法,结合实例形式分析了Laravel5.1 框架Request请求操作常见的属性和方法,及相关操作注意事项,需要的朋友可以参考下

  4. laravel5.1框架基础之路由详解

    这篇文章主要介绍了laravel5.1框架基础之路由,结合实例形式分析了Laravel框架中路由的概念、原理、基本路由操作与相关注意事项,需要的朋友可以参考下

  5. Laravel5.1 框架模型多态关联用法实例分析

    这篇文章主要介绍了Laravel5.1 框架模型多态关联用法,结合实例形式分析了laravel5.1框架模型多态关联具体实现、使用方法与操作注意事项,需要的朋友可以参考下

  6. Laravel5.1 框架模型一对一关系实现与使用方法实例分析

    这篇文章主要介绍了Laravel5.1 框架模型一对一关系实现与使用方法,结合实例形式分析了laravel5.1框架模型一对一关系的原理、定义与使用方法,需要的朋友可以参考下

  7. Laravel5.1 框架Middleware中间件基本用法实例分析

    这篇文章主要介绍了Laravel5.1 框架Middleware中间件基本用法,结合实例形式分析了laravel5.1框架Middleware中间件功能、创建、使用方法及相关操作注意事项,需要的朋友可以参考下

  8. Laravel5.1 框架关联模型之后操作实例分析

    这篇文章主要介绍了Laravel5.1 框架关联模型之后操作,结合实例形式分析了laravel5.1框架写入关联模型、更新关联关系等相关操作技巧与注意事项,需要的朋友可以参考下

  9. Laravel5.1 框架登录和注册实现方法详解

    这篇文章主要介绍了Laravel5.1 框架登录和注册实现方法,结合实例形式详细分析了laravel5.1框架登录与注册相关配置、路由、实现方法与操作注意事项,需要的朋友可以参考下

  10. laravel5.1框架model类查询的实现方法

    今天小编就为大家分享一篇laravel5.1框架model类查询的实现方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

随机推荐

  1. PHP个人网站架设连环讲(一)

    先下一个OmnihttpdProffesinalV2.06,装上就有PHP4beta3可以用了。PHP4给我们带来一个简单的方法,就是使用SESSION(会话)级变量。但是如果不是PHP4又该怎么办?我们可以假设某人在15分钟以内对你的网页的请求都不属于一个新的人次,这样你可以做个计数的过程存在INC里,在每一个页面引用,访客第一次进入时将访问时间送到cookie里。以后每个页面被访问时都检查cookie上次访问时间值。

  2. PHP函数学习之PHP函数点评

    PHP函数使用说明,应用举例,精简点评,希望对您学习php有所帮助

  3. ecshop2.7.3 在php5.4下的各种错误问题处理

    将方法内的函数,分拆为2个部分。这个和gd库没有一点关系,是ecshop程序的问题。会出现这种问题,不外乎就是当前会员的session或者程序对cookie的处理存在漏洞。进过本地测试,includes\modules\integrates\ecshop.php这个整合自身会员的类中没有重写integrate.php中的check_cookie()方法导致,验证cookie时返回的username为空,丢失了登录状态,在ecshop.php中重写了此方法就可以了。把他加到ecshop.php的最后面去就可

  4. NT IIS下用ODBC连接数据库

    $connection=intodbc_connect建立数据库连接,$query_string="查询记录的条件"如:$query_string="select*fromtable"用$cur=intodbc_exec检索数据库,将记录集放入$cur变量中。再用while{$var1=odbc_result;$var2=odbc_result;...}读取odbc_exec()返回的数据集$cur。最后是odbc_close关闭数据库的连接。odbc_result()函数是取当前记录的指定字段值。

  5. PHP使用JpGraph绘制折线图操作示例【附源码下载】

    这篇文章主要介绍了PHP使用JpGraph绘制折线图操作,结合实例形式分析了php使用JpGraph的相关操作技巧与注意事项,并附带源码供读者下载参考,需要的朋友可以参考下

  6. zen_cart实现支付前生成订单的方法

    这篇文章主要介绍了zen_cart实现支付前生成订单的方法,结合实例形式详细分析了zen_cart支付前生成订单的具体步骤与相关实现技巧,需要的朋友可以参考下

  7. Thinkphp5框架实现获取数据库数据到视图的方法

    这篇文章主要介绍了Thinkphp5框架实现获取数据库数据到视图的方法,涉及thinkPHP5数据库配置、读取、模型操作及视图调用相关操作技巧,需要的朋友可以参考下

  8. PHP+jquery+CSS制作头像登录窗(仿QQ登陆)

    本篇文章介绍了PHP结合jQ和CSS制作头像登录窗(仿QQ登陆),实现了类似QQ的登陆界面,很有参考价值,有需要的朋友可以了解一下。

  9. 基于win2003虚拟机中apache服务器的访问

    下面小编就为大家带来一篇基于win2003虚拟机中apache服务器的访问。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  10. Yii2中组件的注册与创建方法

    这篇文章主要介绍了Yii2之组件的注册与创建的实现方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下

返回
顶部