浅谈laravel5.5 belongsToMany自身的正确用法


Posted in PHP onOctober 17, 2019

场景

用户之间相互关注,记录这种关系的是followers表(follower_id 发起关注的人 followed_id被关注的人)

现在的多对多的关系就不再是传统的三张表的关系了, 这种情况 多对多关系应该怎么声明呢?

分析

laravel或者其他框架多对多的关系 一般都是由Model1 Model2 Model1_Model2(声明两者关系的表)来组成,

但是上面的场景 却是只有两张表,这时候就要研究下官方文档了; 当然是支持的

参考资料

https://laravel.com/docs/5.6/eloquent-relationships#many-to-many

In addition to customizing the name of the joining table, you may also customize the column names of the keys on the table by passing additional arguments to the belongsToMany method. The third argument is the foreign key name of the model on which you are defining the relationship, while the fourth argument is the foreign key name of the model that you are joining to:

belongsToMany方法传递的参数是可以定制的 以达到个性化的需求,

第一个参数是 第二个Model

第二个参数是 关系表名

第三个参数是 第一个Model在关系表中的外键ID

第四个参数是 第二个Model在关系表中的外键ID

解决

经过分析

1. 第一个Model是User 第一个Model也是User

2. 关系表名是 'followers'

/**
  * 关注当前用户的
  * @return \Illuminate\Database\Eloquent\Relations\BelongsToMany
  */
 public function followers()
 {
  return $this->belongsToMany(self::class, 'followers', 'followed_id','follower_id')->withTimestamps()
   ->withTimestamps();
 }

 /**
  * 被当前用户关注的用户
  */
 public function followed()
 {
  return $this->belongsToMany(self::class, 'followers', 'follower_id', 'followed_id');
 }

以上这篇浅谈laravel5.5 belongsToMany自身的正确用法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
PHP中的日期及时间
Nov 23 PHP
PHP中的日期处理方法集锦
Jan 02 PHP
Zend Studio (eclipse)使用速度优化方法
Mar 23 PHP
PHP中函数rand和mt_rand的区别比较
Dec 26 PHP
php函数array_merge用法一例(合并同类数组)
Feb 03 PHP
php setcookie(name, value, expires, path, domain, secure) 参数详解
Jun 28 PHP
php获取mysql字段名称和其它信息的例子
Apr 14 PHP
Linux下手动编译安装PHP扩展的例子分享
Jul 15 PHP
php使用PDO方法详解
Dec 27 PHP
php微信开发之批量生成带参数的二维码
Jun 26 PHP
PHP设计模式之工厂模式与单例模式
Sep 28 PHP
Laravel网站打开速度优化的方法汇总
Jul 16 PHP
解决laravel5.4下的group by报错的问题
Oct 16 #PHP
laravel ORM关联关系中的 with和whereHas用法
Oct 16 #PHP
laravel 模型查询按照whereIn排序的示例
Oct 16 #PHP
解决Laravel无法使用COOKIE和SESSION的问题
Oct 16 #PHP
laravel 使用事件系统统计浏览量的实现
Oct 16 #PHP
关于laravel 子查询 & join的使用
Oct 16 #PHP
laravel高级的Join语法详解以及使用Join多个条件
Oct 16 #PHP
You might like
PHPnow安装服务[apache_pn]失败的问题的解决方法
2010/09/10 PHP
php发送与接收流文件的方法
2015/02/11 PHP
php通过修改header强制图片下载的方法
2015/03/24 PHP
PHP+Apache环境中如何隐藏Apache版本
2017/11/24 PHP
高效率JavaScript编写技巧整理
2013/08/23 Javascript
javascript实现简单的贪吃蛇游戏
2015/03/31 Javascript
在Node.js应用中使用Redis的方法简介
2015/06/24 Javascript
javascript基于prototype实现类似OOP继承的方法
2015/12/16 Javascript
javascript RegExp 使用说明
2016/05/21 Javascript
使用JQuery 加载页面时调用JS的实现方法
2016/05/30 Javascript
关于jquery中动态增加select,事件无效的快速解决方法
2016/08/29 Javascript
jQuery点击导航栏选中更换样式的实现代码
2017/01/23 Javascript
简单谈谈gulp-changed插件
2017/02/21 Javascript
JavaScript设置名字输入不合法的实现方法
2017/05/23 Javascript
JS数组求和的常用方法总结【5种方法】
2019/01/14 Javascript
javascript 内存模型实例详解
2020/04/18 Javascript
python使用ctypes模块调用windowsapi获取系统版本示例
2014/04/17 Python
理解Python中的类与实例
2015/04/27 Python
Django应用程序中如何发送电子邮件详解
2017/02/04 Python
windows上安装Anaconda和python的教程详解
2017/03/28 Python
对python中大文件的导入与导出方法详解
2018/12/28 Python
scrapy-redis源码分析之发送POST请求详解
2019/05/15 Python
python实现websocket的客户端压力测试
2019/06/25 Python
Python递归函数特点及原理解析
2020/03/04 Python
Keras SGD 随机梯度下降优化器参数设置方式
2020/06/19 Python
详解Scrapy Redis入门实战
2020/11/18 Python
html5移动端价格输入键盘的实现
2019/09/16 HTML / CSS
MSC邮轮官方网站:加勒比海、地中海和世界各地的假期
2018/08/27 全球购物
雷朋巴西官方商店:Ray-Ban Brasil
2020/07/21 全球购物
广告设计应届生求职信
2014/03/01 职场文书
商铺门面租房协议书
2014/10/21 职场文书
关于感谢信的范文
2015/01/23 职场文书
微观世界观后感
2015/06/10 职场文书
关于销售人员的年终工作总结要点
2019/08/15 职场文书
创业计划书之网吧
2019/10/10 职场文书
springboot入门 之profile设置方式
2022/04/04 Java/Android