dongweihuai5601 2018-04-20 12:02
浏览 93
已采纳

如何加载多级关系?

I am trying to search in 3 related tables as follows contracts belongsTo -> companies hasMany -> company_addresses.I would like to display company_addresses data in the contracts view.

contracts
    id – integer
    company_id - integer
    title – string 

companies
    id - integer
    name – string

company_addresses
    id - integer
    company_id - integer
    address – string
    complement – string
    contact– string

Model contracts

public function company()
{
    return $this->belongsTo(Company::class, 'company_id', 'id');
}

Model companies

public function contracts ()
{
    return $this->hasMany(Contract::class);
} 
public function addresses()
{
    return $this->hasMany(CompanyAddress::class);
}

Model company_addresses

public function company()
{
    return $this->belongsTo(Company::class);
}

Code Contract Controller

 public function index()
 {
     $contract= Contract::with('companies.company_addresses')->get();
     return view(‘contract.view')->with(compact('contract'));
 }

So what am I doing wrong and how can I fix it? Any help is very valid.

  • 写回答

1条回答 默认 最新

  • dongxingji3882 2018-04-20 12:05
    关注

    You have the wrong child. Change this:

    $contract= Contract::with('companies.company_addresses')->get();
    

    to this

    $contract= Contract::with('company.addresses')->get();
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
  • ¥20 软件测试决策法疑问求解答
  • ¥15 win11 23H2删除推荐的项目,支持注册表等
  • ¥15 matlab 用yalmip搭建模型,cplex求解,线性化处理的方法
  • ¥15 qt6.6.3 基于百度云的语音识别 不会改
  • ¥15 关于#目标检测#的问题:大概就是类似后台自动检测某下架商品的库存,在他监测到该商品上架并且可以购买的瞬间点击立即购买下单
  • ¥15 神经网络怎么把隐含层变量融合到损失函数中?
  • ¥15 lingo18勾选global solver求解使用的算法
  • ¥15 全部备份安卓app数据包括密码,可以复制到另一手机上运行
  • ¥20 测距传感器数据手册i2c