Laravel 负载与模型条件的关系

Posted

技术标签:

【中文标题】Laravel 负载与模型条件的关系【英文标题】:Laravel Load Relation With Condition On Model 【发布时间】:2020-11-24 02:13:37 【问题描述】:

我正在尝试使用取决于通知模型值的关系来急切加载用户的通知:

$notifications = $user->notifications()
    ->with([
        'notifiable' => function ($query) 
            // Only load notifiable relation if notification 'notifiable_type' equals...
        ,
        'notifiable.group:id,title' => function ($query) 
            // Only load notifiable.group:id,title relation if notification 'notifiable_type' equals... 
        
    ])
    ->get();

问题是闭包中的$query 正在查询notifiable 关系而不是通知模型本身......我显然错过了一些非常微不足道的东西。有什么建议吗?

【问题讨论】:

这能回答你的问题吗? Laravel: Create HasMany Relationship Based On Condition @BhaumikPandhi 不,它没有 【参考方案1】:

你可以使用Lazy Eager Loading

$notifications = $user->notifications;

$notifications->each(function ($item) 
    if ($item->notifiable_type == 'value-one') 
        $item->load('notifiable');
    

    if ($item->notifiable_type == 'value-two') 
        $item->load('notifiable.group:id,title');
    
);

【讨论】:

不错!通过检查$this->notifiable_type 和延迟加载,我在通知模型的 API 资源中做了类似的事情,但是我更愿意将该逻辑保留在 API 资源之外。不敢相信我没有想到这个!

以上是关于Laravel 负载与模型条件的关系的主要内容,如果未能解决你的问题,请参考以下文章

Laravel 条件子查询与相关模型最后一个条目

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

Laravel - 按“字段及其关系模型字段”之间的条件过滤模型

Laravel 有一个条件关系

Laravel Eloquent 负载关系中枢轴关系 [已解决]

Laravel - 具有关系条件