dphnn333971 2017-08-03 19:41
浏览 592

Laravel Eloquent在whereIn查询中左边加入

If I have something like the following, how can I add a left join to the "with(new Model)" part?

Model::whereIn('name', function ($query) use ($link) {
    $query->select('name')
        ->from(with(new Model)->getTable()) // would like to do a leftJoin here
        ->where('link', $link);
})->get();

I've tried

Model::whereIn('name', function ($query) use ($link) {
    $query->select('name')
        ->from(with(new Model)->leftJoin('tableZ', Model.col1, '=', tableZ.col1)->getTable())
        ->where('link', $link);
})->get();

I've also tried:

Model::whereIn('name', function ($query) use ($link) {
    $query->select('name')
        ->from(with(new Model)->getTable())
        ->leftJoin('tableZ', Model.col1, '=', tableZ.col1)
        ->where('link', $link);
})->get();

Not exactly sure how I'm supposed to go about doing this.

  • 写回答

3条回答 默认 最新

  • dongsui3297 2017-08-03 20:52
    关注

    Is link a field in tableZ? If so then

    ->where('table.link', $link)
    

    might be what you want. I'd use that in your second example; I don't think applying the leftJoin() directly to the with function works, as with() appears to return a model object, not a query.

    评论

报告相同问题?

悬赏问题

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