我怎么说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吗?
当前回答
您还可以查询第一个或条件,然后可以应用另一个或条件
$model = Model::where('a',1)->orWhere('b',1);
现在对$model变量应用另一个条件
$model1 = $model->where('c',1)->orWhere('d',1)->get();
其他回答
在Laravel Eloquent中简单使用:
$a='foo', $b='bar', $c='john', $d='doe';
Coder::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);
})->get();
将产生如下查询:
SELECT * FROM <table> WHERE (a='foo' or b='bar') AND (c='john' or d='doe');
如果你想在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);
});
这是我的结果:
$a, $b, $c, $d可以是查询的动态值
->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()
您还可以查询第一个或条件,然后可以应用另一个或条件
$model = Model::where('a',1)->orWhere('b',1);
现在对$model变量应用另一个条件
$model1 = $model->where('c',1)->orWhere('d',1)->get();