如何解决Laravel:一对多关系中的自定义外键无法解决
有两个模型 User 和 Submission ,并且User可以具有任意数量的提交,其中他被称为 Author 。我已经根据documentation建立了关系,
hasMany()
的结果工作正常。只有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
定义自定义外键并将列重命名为{时,可以正确解决从提交到用户的关系。 {1}}。
有效的配置是这样的:
author_id
我感觉自己缺少一些东西。我还需要建立其他链接吗?我浏览了文档和网络中的解决方案,但没有成功。如果没有其他解决方案,我将重命名该列。但是我宁愿了解造成问题的原因,并使用我的原始设计。
解决方法
您不应使用相同的字符串来命名关系函数和字段。
当您有author
列并且有public function author()
的Laravel首先进入列内容时。
在该列中添加“ _id”,因此您无需在$this->belongsTo( 'App\User','author' );
中定义引用的字段。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。