3分钟短文:Laravel 模型一对一关联关系这俩啥区别
引言
本期我们把目光投向laravel模型的关联关系上。框架提供的关联关系,有很多种,其中对于一对一的关系, 有两个写法,一个是 belongsTo,一个是 hasOne,这俩到底啥区别,本文就来说一说。
学习时间
从文档上讲,belongsTo 是 hasOne 的逆函数。拿User表作为示例,比如一个用户,只有一个手机号, 首先使用 hasOne 方式定义关联:
class User extends Model
{
/**
* 获取与user对应的phone记录
*/
public function phone()
{
return $this->hasOne('AppPhone');
}
}
使用上述的 hasOne 方法,可以使用 user->phone 返回一个 Phone 模型对象,但是反过来不行, 你不能通过 Phone 获取 User,也就是
要达到这个目的,你需要在 Phone 模型中,相应地定义 Phone 到 User 的对应关系,如下:
class Phone extends Model
{
/**
* 通过 phone 查找对应 user
*/
public function user()
{
return $this->belongsTo('AppUser');
}
}
虽然这样写了,大家也许还看的迷迷糊糊。因为关联关系的第二个,第三个参数,根本没有填写。所以这样对比是不直观的。
hasOne 和 belongsTo 最大的不同,是哪一方持有关系的外键。
举个例子,比如User表,还有一个 Car表,为了简化逻辑关系, 我们假设一个user只有一个car。我们在car表内设计一个 user_id 字段,用于存储 user 表的 id 值。那么模型设计起来就应该是这样的:
class User extends Model
{
public function car()
{
// $user->car 返回一个 Car 模型对象
return $this->hasOne('Car');
}
}
然后就是 Car 到 User 的反关系,外键为 user_id,定义关联关系:
class Car extends Model
{
public function user()
{
// car 表有一个 user_id 字段
return $this->belongsTo('User', 'user_id', 'id');
}
}
再说一个一对多的关系示例,比如说一个用户有多个手机号,那么使用 hasMany 关联模型:
class User extends Model
{
public function phones()
{
// $user->phones 会返回一个 Phone 模型的集合
return $this->hasMany('Phone');
}
}
那么反过来,我们在 phone 表内使用 user_id 存储用户的id,定义反向关系,这样写:
class Phone extends Model
{
public function owner()
{
return $this->belongsTo('User', 'user_id', 'id');
}
}
所以,反向关系无关于原始的一对一,或者一对多,因为数据库表内存储了外键,所以使用这个belongsTo对应回去。
写在最后
本文通过几个实例介绍了数据库模型的一对一,一对多,以及反向关联关系, 大家记住一点,belongsTo 是根据当前表存储的外键,去主表内查找记录,而且是返回一个模型对象,或者null。至于 hasOne hasMany 则是定义的主表的关系。大家多多练习体会一下。
- php概述
- php教程
- php环境搭建
- PHP书写格式
- php变量
- php常量
- PHP注释
- php数组
- php字符串 string
- PHP整型 integer
- PHP浮点型 float
- php布尔型
- php数据类型之数组
- php数据类型之对象
- php数据类型之null
- php数据类型之间的转换
- php运算符
- php表达式
- PHP循环控制
- PHP流程控制
- php函数
- php全局变量
- PHP魔术变量
- php命名空间
- php 日期
- PHP包含文件
- php文件
- PHP 文件上传
- php Cookies
- php Sessions
- php email
- php安全email
- php错误处理
- PHP异常处理
- php过滤器
- PHP 高级过滤器
- php json
- php 表单
- PHP MySQL 简介
- PHP 连接 MySQL
- php创建数据库
- php 创建表
- php mysq 插入数据
- PHP MySQL 插入多条数据
- PHP MySQL 预处理语句
- php mysql 读取数据
- php mysql where
- PHP MySQL Order By
- PHP MySQL Update
- PHP MySQL Delete
- php ODBC
- Codeforce-Ozon Tech Challenge 2020-D. Kuroni and the Celebration(交互题+DFS)
- Codeforce 263D Cycle in Graph 搜索 图论 哈密尔顿环
- codeforce 266c Below the Diagonal 矩阵变换 (思维题)
- Codeforce-Ozon Tech Challenge 2020-C. Kuroni and Impossible Calculation(鸽笼原理)
- 探索ParNew和CMS垃圾回收器
- Codeforce-Ozon Tech Challenge 2020-B. Kuroni and Simple Strings(贪心)
- 第K短路+严格第K短路
- PostgreSQL异常重启postmaster.pid处理
- Codeforce-Ozon Tech Challenge 2020-A. Kuroni and the Gifts
- 洛谷P3360偷天换日(树形DP)
- Java开发编程规范: 2.常量定义
- Codeforces Round #509 (Div. 2) A. Heist 贪心
- CodeForces - 1176A Divide it! (模拟+分类处理)
- Codeforces Round #460 (Div. 2)-A Supermaket(贪心)
- Codeforces Round #561 (Div. 2) A. Silent Classroom(贪心)