首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >3分钟短文:Laravel 模型一对一关联关系这俩啥区别

3分钟短文:Laravel 模型一对一关联关系这俩啥区别

作者头像
程序员小助手
发布2020-09-10 14:50:15
发布2020-09-10 14:50:15
3.2K0
举报
文章被收录于专栏:程序员小助手程序员小助手

引言

本期我们把目光投向laravel模型的关联关系上。框架提供的关联关系,有很多种,其中对于一对一的关系, 有两个写法,一个是 belongsTo,一个是 hasOne,这俩到底啥区别,本文就来说一说。

学习时间

从文档上讲,belongsTo 是 hasOne 的逆函数。拿User表作为示例,比如一个用户,只有一个手机号, 首先使用 hasOne 方式定义关联:

代码语言:javascript
复制
class User extends Model
{
    /**
     * 获取与user对应的phone记录
     */
    public function phone()
    {
        return $this->hasOne('App\Phone');
    }
}

使用上述的 hasOne 方法,可以使用 user->phone 返回一个 Phone 模型对象,但是反过来不行, 你不能通过 Phone 获取 User,也就是

要达到这个目的,你需要在 Phone 模型中,相应地定义 Phone 到 User 的对应关系,如下:

代码语言:javascript
复制
class Phone extends Model
{
    /**
     * 通过 phone 查找对应 user
     */
    public function user()
    {
        return $this->belongsTo('App\User');
    }
}

虽然这样写了,大家也许还看的迷迷糊糊。因为关联关系的第二个,第三个参数,根本没有填写。所以这样对比是不直观的。

hasOne 和 belongsTo 最大的不同,是哪一方持有关系的外键。

举个例子,比如User表,还有一个 Car表,为了简化逻辑关系, 我们假设一个user只有一个car。我们在car表内设计一个 user_id 字段,用于存储 user 表的 id 值。那么模型设计起来就应该是这样的:

代码语言:javascript
复制
class User extends Model
{
  public function car()
  {
    // $user->car 返回一个 Car 模型对象
    return $this->hasOne('Car');
  }
}

然后就是 Car 到 User 的反关系,外键为 user_id,定义关联关系:

代码语言:javascript
复制
class Car extends Model
{
  public function user()
  {
    // car 表有一个 user_id 字段
    return $this->belongsTo('User', 'user_id', 'id');
  }
}

再说一个一对多的关系示例,比如说一个用户有多个手机号,那么使用 hasMany 关联模型:

代码语言:javascript
复制
class User extends Model
{
  public function phones()
  {
    // $user->phones 会返回一个 Phone 模型的集合
    return $this->hasMany('Phone');
  }
}

那么反过来,我们在 phone 表内使用 user_id 存储用户的id,定义反向关系,这样写:

代码语言:javascript
复制
class Phone extends Model
{
  public function owner()
  {
    return $this->belongsTo('User', 'user_id', 'id');
  }
}

所以,反向关系无关于原始的一对一,或者一对多,因为数据库表内存储了外键,所以使用这个belongsTo对应回去。

写在最后

本文通过几个实例介绍了数据库模型的一对一,一对多,以及反向关联关系, 大家记住一点,belongsTo 是根据当前表存储的外键,去主表内查找记录,而且是返回一个模型对象,或者null。至于 hasOne hasMany 则是定义的主表的关系。大家多多练习体会一下。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-09-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 程序员小助手 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 引言
  • 学习时间
  • 写在最后
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档