在 laravel 中定义 eloquent 关系时添加额外的约束

Posted

技术标签:

【中文标题】在 laravel 中定义 eloquent 关系时添加额外的约束【英文标题】:Adding additional contraints when defining an eloquent relation in laravel 【发布时间】:2021-02-04 01:51:53 【问题描述】:

在模型中定义有说服力的关系时,有没有办法使用附加条件?

假设我有:

public function researchtopic() 
    return $this->belongsTo('App\ResearchTopic', 'taggable_id');

但我想添加一个额外的 where 条件以在关系中使用第二列。

如何添加第二个条件:

WHERE taggable_type = "研究主题"

【问题讨论】:

“类型”在哪里?或者'taggable_type'在哪里? 一般情况下,但这次是“WHERE taggable_type = 'ResearchTopic'” 【参考方案1】:

你可以在 belongsTo 参数之后直接使用“where”方法,或者使用 laravel Scope 为关系添加条件:

public function researchtopic() 
    return $this->belongsTo('App\ResearchTopic', 'taggable_id')->where('taggable_type', 'ResearchTopic');

https://laravel.com/docs/8.x/eloquent#local-scopes

【讨论】:

以上是关于在 laravel 中定义 eloquent 关系时添加额外的约束的主要内容,如果未能解决你的问题,请参考以下文章

我需要帮助定义 Laravel Eloquent 关系

未定义的属性:Illuminate\Database\Eloquent\Relations\BelongsTo::$status。 Laravel 5.5 关系

Laravel Eloquent ORM 关系命名约定

在 Laravel 中使用 Eloquent 多态关系对数据进行分类

Laravel Eloquent 一对一关系返回空集合

Laravel Eloquent 关系有很多错误:在 where 上使用时调用未定义的方法