如何在laravel eloquent
中生成如下所示的查询SELECT *
FROM TABLE
WHERE column1=value1
and (
(column2=value2 or column3=value3)
or (column4=value4 or column5=value5)
)
请帮忙。
答案 0 :(得分:1)
您的查询可以表示为
SELECT *
FROM table
WHERE column1=value1
AND (
column2=value2
or column3=value3
or column4=value4
or column5=value5
)
要在laravel中使用上述内容,您可以按照文档
中的Parameter Grouping指南进行操作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();
答案 1 :(得分:0)
您需要使用两个嵌套的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()
答案 2 :(得分:0)
试试吧
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();