【问题标题】:Eloquent grouped orWhere雄辩的分组orWhere
【发布时间】:2015-12-09 23:12:46
【问题描述】:

目前有一个 Eloquent 声明:

$contacts = Contacts::where('lname','LIKE',$searchquery.'%')
    ->orWhere('fname','LIKE',$searchquery.'%')
    ->orWhere('phone','LIKE','%'.$searchquery)
    ->where('active','=',1)->get();

它把它当作

select 
    * 
from 
    contacts 
where 
    lname like $searchquery+'%' 
    or lname like $searchquery+'%' 
    or lname like $searchquery+'%' 
    and active = 1

我需要的是

select 
    * 
from 
    contacts 
where 
    (lname like $searchquery+'%' 
    or lname like $searchquery+'%' 
    or lname like $searchquery+'%') 
    and active = 1

如何在 Eloquent 中进行分组?我发现了几个例子,例如:

DB::table('users')
        ->where('name', '=', 'John')
        ->orWhere(function ($query) {
            $query->where('votes', '>', 100)
                  ->where('title', '<>', 'Admin');
        })
        ->get();

但我只习惯于 Eloquent,而不是 Laravels DB Query builder。我尝试使 Eloquent 形式适应这个

$contacts = Contacts::->where('active', '=', '1')
        ->where(function ($query) {
            $query->orWhere('lname', 'LIKE', $searchquery.'%')
                  ->orWhere('lname', 'LIKE', $searchquery.'%')
                  ->orWhere('phone', 'LIKE', '%'.$searchquery);
        })
        ->get();

没有成功,因为它无法识别函数内部的$searchquery

我错过了什么?

【问题讨论】:

    标签: php laravel-5 eloquent


    【解决方案1】:

    所以,这就是你必须做的:

    DB::table('users')->where(function($query) use ($searchQuery){
                                    $query->where('lname', 'LIKE', $searchQuery . '%')
                                          ->orWhere('fname', 'LIKE', $searchQuery . '%')
                                          ->orWhere('phone','LIKE', '%' . $searchquery);
                              })
                              ->get();
    

    请注意,我已经使用 ($searchQuery),所以它可以在闭包内使用

    【讨论】:

    • 成功了!必须在表格之前添加connection('contacts'),因为它不是来自 mt 默认连接,但可以工作!谢谢
    【解决方案2】:

    当您将orWhere 与多个where 子句一起使用时,您需要小心!

    Where 子句 after orWhere 不影响兄弟 where 子句 before orWhere 子句,例如 where, whereHas, whereDoesntHave, orWhereHas

    您还必须在其中使用use ($searchquery) 传递$searchquery 变量以在where 子句中运行

    Contacts::->where(function ($query) use ($searchquery) {
                    $query->orWhere('lname', 'LIKE', $searchquery.'%')
                          ->orWhere('lname', 'LIKE', $searchquery.'%')
                          ->orWhere('phone', 'LIKE', '%'.$searchquery);
                })
                ->where('active', '=', '1')
                ->get();
    

    【讨论】:

      猜你喜欢
      • 2023-04-05
      • 2014-06-27
      • 1970-01-01
      • 2018-02-19
      • 2018-04-21
      • 2020-01-14
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多