簡體   English   中英

Laravel口才查詢中的SQL查詢

[英]SQL query in Laravel Eloquent Query

如何在laravel雄辯中產生如下所示的查詢

SELECT *
FROM TABLE
WHERE column1=value1 
and (
        (column2=value2 or column3=value3) 
     or (column4=value4 or column5=value5)
)

請幫忙。

您的查詢可以表示為

SELECT * 
FROM table 
WHERE column1=value1 
AND (
       column2=value2 
    or column3=value3 
    or column4=value4 
    or column5=value5
)

要在laravel中使用以上內容,您可以遵循docs中的參數分組指南

DB::table('table')
    ->where('column1', $value1)
    ->where(function ($query) use ($value2, $value3, $value4, $value5) {
        $query->where('column2', $value2)
          ->orWhere('column3', $value3)
          ->orWhere('column4', $value4)
          ->orWhere('column5', $value5)
          ;
    })
    ->get();

您需要使用兩個嵌套的where()語句:

DB::table('the_table')
    ->where('column', 'val')
    ->where(function ($q) {
        $q->where('column1', 'val1')
            ->orWhere('column2', 'val2');
    })
    ->where(function ($q) {
        $q->where('column3', 'val3')
            ->orWhere('column4', 'val4');
    })
    ->get()

如果需要將變量傳遞給嵌套的where() ,則需要在內聯函數上添加一個use

DB::table('the_table')
    ->where('column', $val)
    ->where(function ($q) use ($val1, $val2) {
        $q->where('column1', $val1)
            ->orWhere('column2', $val2);
    })
    ->where(function ($q) {
        $q->where('column3', 'val3')
            ->orWhere('column4', 'val4');
    })
    ->get()

試試吧

DB::table('the_table')
    ->where('column1', 'value1')
    ->where(function ($query) {
        $query->where(function ($query) {
            $query->where('column2', 'value2')
                ->orWhere('column3', 'value3');
        })->orWhere(function ($query) {
            $query->where('column4', 'value4')
            ->orWhere('column5', 'value5');
        });
    })->get();

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM