Laravel 有一个条件关系

Posted

技术标签:

【中文标题】Laravel 有一个条件关系【英文标题】:Laravel hasOne conditional relationship 【发布时间】:2014-11-30 22:49:14 【问题描述】:

我有一个用户模型,每个用户都有一个内部或外部类型。内部和外部用户存储的数据非常不同,因此存在单独的 UserInternal 和 UserExternal 模型。

如何定义这种关系? UserInternal 和 UserExternal 表中有一个键“user_id”,每个用户在其中一个表中都有一个匹配的行。

当我检索用户数据时,它总是通过用户模型,但我想要扩展数据。

我该怎么做呢?我试过这个,但它并不总是有效(例如,如果我尝试 User::with('data') -> find(1) 它不会工作,因为 $this 还没有设置。

在用户模型内:

public function data()

    if( $this -> type === 'internal' )
    
        return $this -> hasOne('UserInternal');
    
    else
    
        return $this -> hasOne('UserExternal');
    

【问题讨论】:

【参考方案1】:

获取用户后尝试加载关系:

$user = User::find(1);

if( ! is_null($user))

    $user->load('data');

【讨论】:

是的 - 看起来这将是我要走的路,只是想知道是否会有更高级的选择! @Ryu_hayabusa 你指的是什么方法?如果我没记错的话,只是关系方法必须是驼峰式。【参考方案2】:

我认为您不能在 Eloquent 模型中将 find() 链接到其他任何内容之后。

与其他答案相反的另一种选择是:

User::with('data')->where('user_id', 1)->first();

【讨论】:

链接确实有效,但前提是没有条件。因此,如果它总是返回第一个选项,它工作正常 嗯,好的。谢谢,看起来你还是找到了答案:)。

以上是关于Laravel 有一个条件关系的主要内容,如果未能解决你的问题,请参考以下文章

laravel - 为关系添加条件

Laravel 4.1 多对多关系和条件在哪里?

Laravel Eager Load 在条件关系中变为空

Laravel - 具有关系条件

Laravel 5.8 中 hasMany 关系的条件

Laravel 用户模型条件预加载(带)