[英]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.