Laravel 8 一对多 (反向)
现在我们已经可以访问文章中的所有评论了,让我们再定义一个关系,以允许评论 (comment) 获取它所属的文章 (post) 。这个关联则是 hasMany
关联的反向关联,需要在子模型中使用 belongsTo
方法来定义它:
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
class Comment extends Model
{
/**
* 获取该评论的所属文章
*/
public function post()
{
return $this->belongsTo('App\Models\Post');
}
}
在这个关系定义好后,我们就可以通过访问 Comment
模型中的「动态属性」post
来获取关联的 Post
模型了:
$comment = App\Models\Comment::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('App\Models\Post', 'foreign_key');
}
如果你的父级数据表不使用 id
作为它的主键,或者你希望用不同的字段来连接子级模型,你可以通过向 belongsTo
方法传递三个参数的形式来指定父级数据表的自定义键:
/**
* 获取该评论的所属文章
*/
public function post()
{
return $this->belongsTo('App\Models\Post', 'foreign_key', 'other_key');
}