duanbozhong9689 2017-10-11 08:57
浏览 32
已采纳

Laravel Query构建器,如何拥有1个领先的地方和其他地方?

I'm having a problem with my query.

I want to filter through all Orders where user_id is the authenticated user. And run the searchquery on field number1 and field number2.

Query:

$query = Order::query();

$query->where('user_id', Auth()->id())
      ->where('number','LIKE', '%' . $searchquery . '%')
      ->orWhere('number2,'LIKE', '%' . $searchquery . '%')
      ->with('user');

I want to ALWAYS check where user_id is Auth()->id();

But when i run this orWhere it also gets orders from other users.

Thanks in advance.

  • 写回答

1条回答 默认 最新

  • dougongyou7364 2017-10-11 09:05
    关注

    Do it like this :

    $query = Order::query();
    
    $query->where('user_id', Auth()->id())
          ->where(function ($query) use ($searchquery) {
                $query->where('number','LIKE', '%' . $searchquery . '%');
                $query->orWhere('number2,'LIKE', '%' . $searchquery . '%');
            })
         ->with('user');
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 在获取boss直聘的聊天的时候只能获取到前40条聊天数据
  • ¥20 关于URL获取的参数,无法执行二选一查询
  • ¥15 液位控制,当液位超过高限时常开触点59闭合,直到液位低于低限时,断开
  • ¥15 marlin编译错误,如何解决?
  • ¥15 有偿四位数,节约算法和扫描算法
  • ¥15 VUE项目怎么运行,系统打不开
  • ¥50 pointpillars等目标检测算法怎么融合注意力机制
  • ¥20 Vs code Mac系统 PHP Debug调试环境配置
  • ¥60 大一项目课,微信小程序
  • ¥15 求视频摘要youtube和ovp数据集