阅读(4979)
赞(9)
Laravel 8 一对多 (反向)
2021-07-07 11:41:20 更新
现在我们已经可以访问文章中的所有评论了,让我们再定义一个关系,以允许评论 (comment) 获取它所属的文章 (post) 。这个关联则是 hasMany
关联的反向关联,需要在子模型中使用 belongsTo
方法来定义它:
<?php
namespace AppModels;
use IlluminateDatabaseEloquentModel;
class Comment extends Model
{
/**
* 获取该评论的所属文章
*/
public function post()
{
return $this->belongsTo('AppModelsPost');
}
}
在这个关系定义好后,我们就可以通过访问 Comment
模型中的「动态属性」post
来获取关联的 Post
模型了:
$comment = AppModelsComment::find(1);
echo $comment->post->title;
在上面的例子中,Eloquent 将会尝试匹配 Comment
模型中的 post_id
和 Post
模型中的 id
。Eloquent 会通过检查关联方法名,并在该关联方法名后方加上 _
再加上主键后缀名来确定默认外键名 (foreign_key) 。当然,如果 Comment
模型的外键名不是 post_id
, 你也可以通过向 belongsTo
方法传递第二个参数以作为自定义键名:
/**
* 获取该评论的所属文章
*/
public function post()
{
return $this->belongsTo('AppModelsPost', 'foreign_key');
}
如果你的父级数据表不使用 id
作为它的主键,或者你希望用不同的字段来连接子级模型,你可以通过向 belongsTo
方法传递三个参数的形式来指定父级数据表的自定义键:
/**
* 获取该评论的所属文章
*/
public function post()
{
return $this->belongsTo('AppModelsPost', 'foreign_key', 'other_key');
}