【问题标题】:Laravel: Custom Foreign Key in One-To-Many Relationship Does Not ResolveLaravel:一对多关系中的自定义外键无法解析
【发布时间】:2020-08-18 18:48:51
【问题描述】:

有两个模型 UserSubmission,一个用户可以有任意数量的提交,其中他被称为 Author。我已经根据documentationhasMany() 的结果工作正常。只有belongsTo() 方法没有返回预期的对象。

这是我的模型的迁移:

Schema::create('users', function (Blueprint $table) {
    $table->id();
});

Schema::create('submissions', function (Blueprint $table) {
    $table->id();
    $table->foreignId( 'author' );
    $table->foreign( 'author' )->references('id')->on('users');
});

这些是我的模型中的关系:

class User extends Authenticatable {
    public function submissions() {
        return $this->hasMany( 'App\Submission', 'author' );
    }
}

class Submission extends Model {
    public function author() {
        return $this->belongsTo( 'App\User', 'author' );
    }
}

现在,我想在我的控制器中执行以下代码:

$author = Submission::find(1)->author;
dd($author);

但是,而不是用户对象,作者 ID 的存储整数值被打印出来。这种关系似乎没有通过author() 方法解决。 另一方面,当我获取用户及其提交的内容时,一切都按预期工作,即提交内容被打印为对象:

$u = User::find(1)->submissions;
dd($u);

但是从提交到用户的关系确实得到正确解决,当我使用belongsTo定义自定义外键并将列重命名为author_id时.

有效的配置是这样的:

//migration for Submissions table
Schema::create('submissions', function (Blueprint $table) {
    $table->id();
    $table->foreignId( 'author_id' );
    $table->foreign( 'author_id' )->references('id')->on('users');
});

//within Submission model
public function author() {
    return $this->belongsTo( 'App\User' );
}

我觉得我错过了什么。我需要做任何额外的链接吗?我浏览了文档和网络以寻找解决方案,但没有成功。如果没有其他解决方案,我将重命名该列。但我更愿意了解问题的原因并使用我的原始设计。

【问题讨论】:

    标签: php laravel eloquent one-to-many belongs-to


    【解决方案1】:

    您不应使用相同的字符串命名关系函数和字段。

    当您有一个列 author 和一个 public function author() 时,laravel 会首先获取列内容。

    在列中添加“_id”,因此您无需在$this->belongsTo( 'App\User', 'author' ); 中定义引用字段。

    【讨论】:

      猜你喜欢
      • 2021-04-04
      • 2019-02-09
      • 2021-12-12
      • 2018-09-08
      • 2019-06-20
      • 1970-01-01
      • 2014-07-30
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多