阅读(4969) (6)

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_idPost 模型中的 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');
}