侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

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

Laravel  /  管理员 发布于 8年前   194

本文实例讲述了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程序设计有所帮助。

您可能感兴趣的文章:

  • 在laravel中实现ORM模型使用第二个数据库设置
  • 使用laravel的Eloquent模型如何获取数据库的指定列
  • Laravel5.1 框架模型多态关联用法实例分析
  • Laravel5.1 框架模型远层一对多关系实例分析
  • Laravel5.1 框架模型一对一关系实现与使用方法实例分析
  • Laravel5.1 框架模型查询作用域定义与用法实例分析
  • Laravel5.1 框架模型软删除操作实例分析
  • Laravel5.1 框架模型创建与使用方法实例分析
  • Laravel框架视图和模型操作方法分析
  • Laravel 5框架学习之模型、控制器、视图基础流程
  • laravel学习教程之关联模型
  • laravel框架模型和数据库基础操作实例详解


  • 上一条:
    laravel框架学习记录之表单操作详解
    下一条:
    Laravel5.1 框架文件管理操作实例分析
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
    • Laravel 11.14版本发布 - 新的字符串助手和ServeCommand改进(0个评论)
    • Laravel 11.12版本发布 - Artisan的`make`命令自动剪切`.php `扩展(0个评论)
    • Laravel的轻量型购物车扩展包:binafy/laravel-cart(0个评论)
    • Laravel 11.11版本发布 - 查看模型中的第三方关系:show(0个评论)
    • 近期文章
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-07
    • 2017-08
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-09
    • 2020-10
    • 2020-11
    • 2021-01
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-04
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客