dsfhe34889 2018-01-03 07:28
浏览 67
已采纳

Laravel Eloquent与同桌的多重关系

I have the following table:

Table: rental_request
Columns:
id int(11) AI PK 
user_id int(11) 
address text 
number varchar(45) 
kvm varchar(45) 
rental varchar(45) 
zip varchar(45) 
city varchar(45) 
timestamp datetime 
created_at datetime 
updated_at datetime 
caseworker int(11)

Where user_id and caseworker points to my users table.

Now i am attempting to create this relationship in my Laravel application:

    class rental_request extends Model
{
    protected $table = 'rental_request';
    protected $fillable = ['user_id','address', 'number', 'kvm','rental','zip','city', 'caseworker'];

    public function user()
    {
        return $this->belongsTo('App\User', 'user_id');
    }

    public function caseworker()
    {
        return $this->hasOne('App\User', 'user_id', 'caseworker');
    }
}

In my controller I collect the data from the table using:

rental_request::orderBy('id', 'desc')->get();

Now, this actually works but only for the user and not for the caseworker.

Which means I have a user object on my result but not a caseworker object.

Can anyone tell me what I've done wrong?

  • 写回答

2条回答 默认 最新

  • dongzan7016 2018-01-03 07:39
    关注

    you can use with to get caseworker

    rental_request::with(['caseworker','user'])->orderBy('id', 'desc')->get();
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 乌班图ip地址配置及远程SSH
  • ¥15 怎么让点阵屏显示静态爱心,用keiluVision5写出让点阵屏显示静态爱心的代码,越快越好
  • ¥15 PSPICE制作一个加法器
  • ¥15 javaweb项目无法正常跳转
  • ¥15 VMBox虚拟机无法访问
  • ¥15 skd显示找不到头文件
  • ¥15 机器视觉中图片中长度与真实长度的关系
  • ¥15 fastreport table 怎么只让每页的最下面和最顶部有横线
  • ¥15 R语言卸载之后无法重装,显示电脑存在下载某些较大二进制文件行为,怎么办
  • ¥15 java 的protected权限 ,问题在注释里