Laravel列名称和关系名称相同
我可以有相同的列名和关系名吗 例如: 我在mack.phpmodel中编辑了一个列,我想从users表中获得edited\u by中提到的用户的完整详细信息,所以我有如下关系Laravel列名称和关系名称相同,laravel,relationship,Laravel,Relationship,我可以有相同的列名和关系名吗 例如: 我在mack.phpmodel中编辑了一个列,我想从users表中获得edited\u by中提到的用户的完整详细信息,所以我有如下关系 public function edited_by(){ return $this->hasOne('App\User','id','edited_by'); } 现在,如果我尝试访问$model->edited\u by->first\u name它的抛出错误“试图获取非对象的属性” 除了
public function edited_by(){
return $this->hasOne('App\User','id','edited_by');
}
现在,如果我尝试访问$model->edited\u by->first\u name它的抛出错误“试图获取非对象的属性”
除了使用不同的名称,还有什么办法可以解决这个问题吗?简单的回答是“没有”。不能让它们具有相同的名称,因为如果找到该列,将始终返回该列,如果找到具有该名称的列,则永远不会返回关系 将列名更改为user_id将比编辑更合适。它更具描述性,也是Eloquent将寻找的默认id。类似地,将关系名称命名为user()比edited\u by()更有意义,因为它返回一个用户模型
稍长但完全不正确的答案是,您可以使用$model->edited_by()访问关系->first_name这将导致不必要地运行额外的查询。此外:PSR-1标准规定,每个方法都应该是camelCase,mysql指南规定,您应该对几个_关键字_列使用下划线。因此,基本上您可以同时使用
editedBy()
方法和editedBy
sql列。资料来源:,