Laravel get Eloquent relation by same name as its attribute(Laravel 获取与其属性同名的 Eloquent 关系)
问题描述
我有这样的数据库表:
shoot: id, name, programme
programme: id, name
拍摄中的雄辩关系是这样定义的:
The eloquent relationship in the shoot is defined like this:
public function programme() {
return $this->belongsTo('AppProgramme', 'programme', 'id');
}
使用 dd()
时,我可以看到这是正常工作的:
When using dd()
, I can see this is working correctly:
dd(Shoot:where('id','=',1)->with('programme')->first());
// prints the object with programme listed under the relationship
但是,当我急切加载拍摄并尝试获取程序对象时,我反而检索了拍摄属性程序".例如:
However when I eager-load the shoot and attempt to get the programme object, I retrieve the shoot attribute "programme" instead. E.g.:
$shoot = Shoot:where('id','=',1)->with('programme')->first();
echo $shoot->programme; // returns 1, not AppProgramme object.
有没有无需重写大量代码库的解决方案?
Is there a solution to this without having to rewrite masses of the codebase?
推荐答案
relationship
和 column
名称不应使用相同的名称,否则您将将始终收到 column
名称,因此尝试编辑其中之一,我认为这里最简单的是 relationship
名称:
You shouldn't use the same name for the both relationship
and column
name, else you'll receive always the column
name so try to edit one of them, I think the easiest one here is the relationship
name :
public function programmeObj() {
return $this->belongsTo('AppProgramme', 'programme', 'id');
}
然后将其称为:
echo $shoot->programmeObj;
注意:但如果你想遵循约定,你应该用 programme_id
替换 name 属性,所以:
NOTE : But if you want to follow conventions you should replace the name attribute by programme_id
so :
public function programme() {
return $this->belongsTo('AppProgramme', 'programme_id', 'id');
}
希望这会有所帮助.
这篇关于Laravel 获取与其属性同名的 Eloquent 关系的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:Laravel 获取与其属性同名的 Eloquent 关系
基础教程推荐
- 在 CakePHP 2.0 中使用 Html Helper 时未定义的变量 2021-01-01
- 找不到类“AppHttpControllersDB",我也无法使用新模型 2022-01-01
- 如何在 Symfony 和 Doctrine 中实现多对多和一对多? 2022-01-01
- 如何在 XAMPP 上启用 mysqli? 2021-01-01
- Doctrine 2 - 在多对多关系中记录更改 2022-01-01
- HTTP 与 FTP 上传 2021-01-01
- 使用 PDO 转义列名 2021-01-01
- PHP 守护进程/worker 环境 2022-01-01
- 在 yii2 中迁移时出现异常“找不到驱动程序" 2022-01-01
- phpmyadmin 错误“#1062 - 密钥 1 的重复条目‘1’" 2022-01-01