¿Cómo se dice "DONDE (a = 1 O b =1 ) Y (c = 1 O d = 1)`?
Para consultas más complicadas, ¿debo utilizar SQL sin formato?
Utiliza Parameter Grouping (Laravel 4.2). Para su ejemplo, sería algo así:
Model::where(function ($query) {
$query->where('a', '=', 1)
->orWhere('b', '=', 1);
})->where(function ($query) {
$query->where('c', '=', 1)
->orWhere('d', '=', 1);
});
Si quieres usar parámetros para a,b,c,d en Laravel 4
Model::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);
});
En caso de que usted & # 39; re bucle de las condiciones de la O, usted don & # 39; t necesidad de la segunda $query-> donde de los otros puestos (en realidad yo don & # 39; no creo que usted necesita en general, sólo puede utilizar orWhere en el anidado donde si más fácil)
$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);
}
});