Laravel: 一对多关系中的自定义外键无法解析
Laravel: Custom Foreign Key in One-To-Many Relationship Does Not Resolve
有两个模型 User 和 Submission 并且用户可以有任意数量的提交,其中他被引用为 作者。我已经根据 documentation 和
hasMany()
的结果工作正常。只有 belongsTo()
方法没有 return 预期的对象。
这是我的模型迁移:
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);
但是从提交到用户的关系确实得到了正确的解决,当我没有用[=19定义自定义外键时=] 并将列重命名为 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' );
}
我觉得我错过了什么。我还需要做额外的 link 吗?我浏览了文档和网络以寻找解决方案,但没有成功。如果没有其他解决方案,我将重命名该列。但我宁愿了解我的问题的原因并使用我的原始设计。
您不应使用相同的字符串命名关系函数和字段。
当您有一个列 author
和一个 public function author()
laravel 时,第一个列内容。
将'_id'添加到列中,因此您无需在$this->belongsTo( 'App\User', 'author' );
中定义引用字段。
有两个模型 User 和 Submission 并且用户可以有任意数量的提交,其中他被引用为 作者。我已经根据 documentation 和
hasMany()
的结果工作正常。只有 belongsTo()
方法没有 return 预期的对象。
这是我的模型迁移:
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);
但是从提交到用户的关系确实得到了正确的解决,当我没有用[=19定义自定义外键时=] 并将列重命名为 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' );
}
我觉得我错过了什么。我还需要做额外的 link 吗?我浏览了文档和网络以寻找解决方案,但没有成功。如果没有其他解决方案,我将重命名该列。但我宁愿了解我的问题的原因并使用我的原始设计。
您不应使用相同的字符串命名关系函数和字段。
当您有一个列 author
和一个 public function author()
laravel 时,第一个列内容。
将'_id'添加到列中,因此您无需在$this->belongsTo( 'App\User', 'author' );
中定义引用字段。