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 则是定义的主表的关系。大家多多练习体会一下。
- 常用的标准SQL 语句
- 更精准!英研究人员利用AI监测预防城市洪水
- 物联网平台的采用将成为2018年首要IT发展趋势
- python基础随笔
- Mysql+Keepalived双主热备高可用操作记录
- Mysql双主热备+LVS+Keepalived高可用操作记录
- 被曝大裁员!曲德君坚称万达网科没有倒下、目标决心不变
- Linux下smokeping网络监控环境部署记录
- Linux下的rsyslog系统日志梳理(用户操作记录审计)
- 数据结构之数组封装
- Centos下内网NDS主从环境部署记录
- 一搜解决,微信的这个功能厉害了!
- Saltstack自动化操作记录(2)-配置使用
- Saltstack自动化操作记录(1)-环境部署
- 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
- Linux系统(CentOS7安装)安装JDK8的教程详解
- Deepin中安装与使用virtualenv的教程
- linux安装jdk并设置环境变量的方法教程(看这一篇够了)
- hadoop基于Linux7的安装配置图文详解
- Linux paste命令的使用方法
- ubuntu下迁移home目录至新的分区教程详解
- SVN服务备份操作步骤分享
- Linux磁盘挂载、分区、扩容操作的实现方法
- linux使用docker-compose部署软件配置详解
- 在Ubuntu中如何查看网络路由表详解
- linux中各种锁机制的使用与区别详解
- Linux环境下使用glog日志库的方法
- crontab执行时间与系统时间不一致问题解决
- Linux内核设备驱动之proc文件系统笔记整理
- CentOS7.6系统下使用yum配置lnmp环境的方法