1. 1.简介:
  2. 1>Eloquent 关联关系以Eloquent模型类方法的形式被定义(是模型类的一个方法)。
  3. 2>同 Eloquent 模型本身一样,关联关系也是强大的查询构建器,定义关联关系为函数能够提供功能强大的方法链和查询能力(也支持一般的where、get、find等方法。
  4. $user->posts()->where('active', 1)->get();
  5. 2.定义关联关系:
  6. 1>一对一
  7. 目标:一个User模型有一个与之对应的Phone模型(以User模型为主)
  8. 实现步骤:
  9. 1.在User模型中,创建phone()方法
  10. 2.在phone()方法中,返回 Eloquent 模型基类上的 'hasOne()' 方法的执行结果
  11. 代码:
  12. class User extends Model{
  13. public function phone(){
  14. return $this->hasOne('App\Phone');       // 参数为 'User模型关联的Phone模型'
  15. }
  16. }
  17. hasOne()方法的3种不同的使用情况:
  18. Eloquent 默认关联关系的外键基于模型名称。默认是:Phone模型的主键是id,关联的外键是user_id
  19. 1.hasOne('App\Phone') - 默认情况
  20. 2.hasOne('App\Phone', 'foreign_key') - Phone模型的主键是id,但是外键不是user_id
  21. 3.hasOne('App\Phone', 'foreign_key', 'local_key') - Phone模型的主键不是id,外键也不是user_id
  22. 调用:
  23. 关联关系被定义后,可以使用 Eloquent 的 '动态属性' 来获取关联关系!
  24. 注意:
  25. 动态属性:允许我们访问关联函数,就像它们是定义在模型上的属性一样!
  26. $phone = User::find(1)->phone;       // 理解 '动态属性' 的概念:按理说,我们定义了 phone() 方法,应该调用的是一个方法,而这里将其作为了一个 '属性' 来调用!
  27. -----------
  28. 定义相对的关联
  29. -----------
  30. 目标:我们可以从User中访问Phone模型,相应的,我们也可以在Phone模型中定义关联关系从而让我们可以拥有该phone的User。
  31. 实现步骤:
  32. 1.在Phone模型中,创建user()方法
  33. 2.在user()方法中,返回 Eloquent 模型基类上的 'belongsTo()' 方法的执行结果
  34. 代码:
  35. class Phone extends Model{
  36. public function user(){
  37. return $this->belongsTo('App\User');     // 参数为 'Phone模型关联的User模型'
  38. }
  39. }
  40. belongsTo()方法的3种不同的使用情况:
  41. Eloquent 默认关联关系的外键基于模型名称。默认是:Phone模型的主键是id,关联的外键是user_id
  42. 1.belongsTo('App\User') - 默认情况
  43. 2.belongsTo('App\User', 'foreign_key') - Phone模型的主键是id,但是外键不是user_id
  44. 3.belongsTo('App\User', 'foreign_key', 'local_key') - Phone模型的主键不是id,外键也不是user_id
  45. 调用:
  46. $user = Phone::find(1)->user;
  47. 总结:
  48. 不管是User模型类,还是Phone模型类,2者都是以 'User' 模型为主。Phone模型还是附属于User模型。Phone模型具有外键 'user_id'
  49. 2>一对多
  50. 定义和使用基本同 '一对一' 一样,只是对应的方法改变了,以 '一个帖子,有多个评论' 为例:
  51. hasMany() - 一个帖子有多个评论
  52. belongsTo() - 一个评论,必然只针对一个帖子(所以,反过来,它还是 'belongsTo' 方法,并未改变)
  53. 3>多对多
  54. 稍微复杂一点。这种关联关系的一个典型例子是:一个用户有多个角色,同时一个角色被多个用户共用。要定义这样的关联关系,需要三个数据表:
  55. users、roles和role_user,role_user表按照关联模型名的字母顺序命名,并且包含user_id和role_id两个列。
  56. 实现步骤:
  57. 1.在User模型中,创建roles()方法
  58. 2.在roles()方法中,返回 Eloquent 模型基类上的 'belongsToMany()' 方法的执行结果
  59. 代码:
  60. class User extends Model{
  61. public function roles()
  62. {
  63. return $this->belongsToMany('App\Role');
  64. }
  65. }
  66. 同样belongsToMany()使用3种方式调用。
  67. -----------
  68. 定义相对的关联
  69. -----------
  70. 同上面一样,只不过是翻过来了。一样使用的是 'belongsToMany()' 方法
  71. -------------------------
  72. 获取中间表的列(本例是:role_user)
  73. -------------------------
  74. 假设User对象有很多与之关联的Role对象,访问这些关联关系之后,我们可以使用模型上的pivot属性访问中间表:
  75. $user = App\User::find(1);
  76. foreach ($user->roles as $role) {
  77. echo $role->pivot->created_at;        // 每一个 '$role' 角色对象,都有一个 'pivot' 属性
  78. }
  79. pivot属性,包含一个代表中间表的模型,并且可以像其它 Eloquent 模型一样使用。
  80. 如果pivot表包含额外的属性(中间表,包含额外的字段),必须在定义关联关系时指定:
  81. return $this->belongsToMany('App\Role')->withPivot('column1', 'column2');
  82. pivot表自动包含created_at和updated_at时间戳,在关联关系定义时使用withTimestamps方法:
  83. return $this->belongsToMany('App\Role')->withTimestamps();
  84. 4>远层的一对多:
  85. countries
  86. id - integer
  87. name - string
  88. users
  89. id - integer
  90. country_id - integer
  91. name - string
  92. posts
  93. id - integer
  94. user_id - integer
  95. title - string
  96. 目标:
  97. 查看一个国家有哪些帖子
  98. 5>多态关联:
  99. posts
  100. id - integer
  101. title - string
  102. body - text
  103. comments
  104. id - integer
  105. post_id - integer
  106. body - text
  107. likes
  108. id - integer
  109. likeable_id - integer
  110. likeable_type - string      // post | comment,喜欢的是贴子还是评论
  111. 目标:
  112. 查询贴子的喜欢数
  113. 评论的喜欢数
  114. 喜欢的这条记录,是贴子还是评论
  115. 6>多对多的多态关联:
  116. posts
  117. id - integer
  118. name - string
  119. videos
  120. id - integer
  121. name - string
  122. tags
  123. id - integer
  124. name - string
  125. taggables ------------ 是不是应该还有个 'id' 主键自增字段
  126. tag_id - integer
  127. taggable_id - integer
  128. taggable_type - string
  129. 目标:
  130. 贴子的标签
  131. 视频的标签
  132. 标签下的所有帖子
  133. 标签下的所有视频
  134. 打标签的这条记录,是'什么标签',类型是帖子还是视频
  135. 3.关联查询:
  136. 4.插入关联模型:
  137. http://blog.csdn.net/beyond__devil/article/details/54233539(原贴地址)

laravel的Eloquent关联关系的更多相关文章

  1. 使用laravel的Eloquent模型获取数据库的指定列

    使用laravel的Eloquent模型获取数据库的指定列   使用Laravel的ORM——Eloquent时,时常遇到的一个操作是取模型中的其中一些属性,对应的就是在数据库中取表的特定列. 如果使 ...

  2. laravel的Eloquent中的get()和Query/Builder中的get()

    Eloquent 中的get实际上是Eloquent/Builder中的get,得到的结果是个Collection对象,再调用Collection的first才得到collection中的一项,即一个 ...

  3. 【laravel】Eloquent 模型事件和监听方式

    所有支持的模型事件 在 Eloquent 模型类上进行查询.插入.更新.删除操作时,会触发相应的模型事件,不管你有没有监听它们.这些事件包括: retrieved 获取到模型实例后触发 creatin ...

  4. Laravel笔记--Eloquent 模型

    Eloquent 模型 默认继承use Illuminate\Database\Eloquent\Model类. 数据表名称与模型名称约定: 数据库的表名一般使用“蛇形命名法”命名.蛇形命名法要求单词 ...

  5. laravel通过Eloquent ORM实现CURD

    //Eloquent ORM public function orm1() { //all(); 返回所有数据: /*$students=Student::all(); dd($students);* ...

  6. Laravel之Eloquent ORM

    一.ORM编程思想 1.1 Active Record 设计模式 Active Record 是一种数据访问设计模式,它可以帮助你实现数据对象Object到关系数据库的映射.应用Active Reco ...

  7. Laravel使用Eloquent ORM操作数据库

    1.定义模型 <?php namespace App; use Illuminate\Database\Eloquent\Model; class Flight extends Model{ p ...

  8. Laravel之Eloquent ORM访问器调整器及属性转换

    一.查询构建器的get方法 查询构建器的get方法返回了一个集合 $users = App\User::where('active', 1)->get(); foreach ($users as ...

  9. Laravel之Eloquent ORM关联

    一.一对一 1.主对从(hasOne) 从User模型中取出用户的手机 User模型中: /** * 获取关联到用户的手机 */ public function phone() { return $t ...

随机推荐

  1. ELK学习目录

    DAY1.elasticsearch和kibana环境搭建以及简单介绍 A:环境搭建配置 (1)java虚拟机安装:https://www.cnblogs.com/studybrother/p/108 ...

  2. Codeforces Round #192 (Div. 2) A. Cakeminator【二维字符数组/吃掉cake,并且是一行或者一列下去,但是该行/列必须没有草莓的存在】

    A. Cakeminator time limit per test 1 second memory limit per test 256 megabytes input standard input ...

  3. Vijos1775 CodeVS1174 NOIP2009 靶形数独

    靶形数独 描述 小城和小华都是热爱数学的好学生,最近,他们不约而同地迷上了数独游戏,好胜的他 们想用数独来一比高低.但普通的数独对他们来说都过于简单了,于是他们向 Z博士请教, Z 博士拿出了他最近发 ...

  4. 《2019年上半年Web应用安全报告》发布:90%以上攻击流量来源于扫描器,IP身份不再可信

    Web应用安全依然是互联网安全的最大威胁来源之一,除了传统的网页和APP,API和各种小程序也作为新的流量入口快速崛起,更多的流量入口和更易用的调用方式在提高web应用开发效率的同时也带来了更多和更复 ...

  5. JavaSript中的正则表达式

    正则表达式是对字符串操作的逻辑公式,表达了对字符串的一种过滤逻辑. 相对于.NET和Perl,JS对正则表达式的支持相当朴素,或者说JS的正则表达式是perl正则表达式的一个子集. 一.正则表达式引擎 ...

  6. virtualenv安装 以及在PyCharm中的使用

    1.安装前条件 python3.7和 pip(可以使用这个命令升级python -m pip install --upgrade pip) 2.安装virtualenv pip install vir ...

  7. Java练习 SDUT-2787_加密术

    加密术 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 加密技术是一种常用的安全保密手段,利用加密技术可以把重要的数据变 ...

  8. Libevent:1前言

    一:libevent概述: libevent是一个用来编写快速.可移植.非阻塞IO程序的库,它的设计目标是:可移植性.高效.可扩展性.便捷. libevent包含下列组件: evutil:对不同平台下 ...

  9. MUI - 为textarea添加语音输入和清除的功能

    为textarea添加语音输入和清除的功能 mui支持input输入框语音输入和清除的功能,只需要添加相关css类即可. http://www.cnblogs.com/phillyx/ 代码如下 &l ...

  10. vmware中配置CentOS

    一.下载 http://mirrors.aliyun.com/centos/7.6.1810/isos/x86_64/CentOS-7-x86_64-DVD-1810.iso 这里选择的是阿里云镜像 ...