为了账号安全,请及时绑定邮箱和手机立即绑定

使用 Laravel Eloquent 的 with() 函数和内部连接

使用 Laravel Eloquent 的 with() 函数和内部连接

PHP
阿波罗的战车 2022-07-16 17:11:44
尝试将with()函数与联接一起使用时遇到问题:$query = Model::query()->with([  'relationOne',  'relationTwo',  ...]);$query->join(DB::raw("(  select *  from <models_table>  where <some_condition>) as new_model"), 'new_model.id', '=', '<models_table>.id');$query->paginate($rpp);通话后paginate($rpp),我收到了所有附加了适当关系的项目,但没有加入表格(又名new_model)。有没有办法new_model与关系一起检索?
查看完整描述

2 回答

?
哈士奇WWW

TA贡献1799条经验 获得超6个赞

您是否尝试添加select语句来强调您想要获取的表?


$query->join(DB::raw("(

  select *

  from <models_table>

  where <some_condition>

) as new_model"), 'new_model.id', '=', '<models_table>.id')

->select(['<models_table>.*', 'new_model.*']);


查看完整回答
反对 回复 2022-07-16
?
莫回无

TA贡献1865条经验 获得超7个赞

请尝试以下代码,希望对您有所帮助。


$query = Model::query()->with([

  'relationOne',

  'relationTwo',

  ...

])


$query = $query->join(DB::raw("(

  select *

  from <models_table>

  where <some_condition>

) as new_model"), 'new_model.id', '=', '<models_table>.id')


$query = $query->paginate($rpp);


查看完整回答
反对 回复 2022-07-16
  • 2 回答
  • 0 关注
  • 247 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号