Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/laravel/10.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Laravel列名称和关系名称相同_Laravel_Relationship - Fatal编程技术网

Laravel列名称和关系名称相同

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它的抛出错误“试图获取非对象的属性” 除了

我可以有相同的列名和关系名吗

例如:

我在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它的抛出错误“试图获取非对象的属性”


除了使用不同的名称,还有什么办法可以解决这个问题吗?

简单的回答是“没有”。不能让它们具有相同的名称,因为如果找到该列,将始终返回该列,如果找到具有该名称的列,则永远不会返回关系

将列名更改为user_id将比编辑更合适。它更具描述性,也是Eloquent将寻找的默认id。类似地,将关系名称命名为user()edited\u by()更有意义,因为它返回一个用户模型


稍长但完全不正确的答案是,您可以使用$model->edited_by()访问关系->first_name这将导致不必要地运行额外的查询。

此外:PSR-1标准规定,每个方法都应该是camelCase,mysql指南规定,您应该对几个_关键字_列使用下划线。因此,基本上您可以同时使用
editedBy()
方法和
editedBy
sql列。资料来源:,