我怎么说WHERE (a =1 OR b =1) AND (c =1 OR d =1)
对于更复杂的查询,我应该使用原始SQL吗?
我怎么说WHERE (a =1 OR b =1) AND (c =1 OR d =1)
对于更复杂的查询,我应该使用原始SQL吗?
当前回答
YourModel::where(function ($query) use($a,$b) {
$query->where('a','=',$a)
->orWhere('b','=', $b);
})->where(function ($query) use ($c,$d) {
$query->where('c','=',$c)
->orWhere('d','=',$d);
});
其他回答
你可以使用:
Model::where('table_column', 'value')->orWhere('table_column', 'value')->get()
使用逻辑分组(Laravel 7.x/4.2)。在你的例子中,它是这样的:
Model::where(function ($query) {
$query->where('a', '=', 1)
->orWhere('b', '=', 1);
})->where(function ($query) {
$query->where('c', '=', 1)
->orWhere('d', '=', 1);
});
如果你循环OR条件,你不需要第二个$查询->where来自其他帖子(实际上我不认为你一般需要,你可以在嵌套的where中使用orWhere如果更容易)
$attributes = ['first'=>'a','second'=>'b'];
$query->where(function ($query) use ($attributes)
{
foreach ($attributes as $key=>value)
{
//you can use orWhere the first time, doesn't need to be ->where
$query->orWhere($key,$value);
}
});
如果你想在laravel 4中使用括号,不要忘记return 在Laravel 4(至少)中,你需要像例子中那样在括号中使用$a, $b
$a = 1;
$b = 1;
$c = 1;
$d = 1;
Model::where(function ($query) use ($a, $b) {
return $query->where('a', '=', $a)
->orWhere('b', '=', $b);
})->where(function ($query) use ($c, $d) {
return $query->where('c', '=', $c)
->orWhere('d', '=', $d);
});
这是我的结果:
这对我很有用
$business = Model::where('model_id', $model_id1)->orWhere('model_id', $model_id2)->first();