Wie sage ich "WO (a = 1 OR b =1 ) AND (c = 1 OR d = 1)`
Soll ich für kompliziertere Abfragen Roh-SQL verwenden?
Verwenden Sie die Parametergruppierung (Laravel 4.2). Für Ihr Beispiel würde es etwa so aussehen:
Model::where(function ($query) {
$query->where('a', '=', 1)
->orWhere('b', '=', 1);
})->where(function ($query) {
$query->where('c', '=', 1)
->orWhere('d', '=', 1);
});
Wenn Sie Parameter für a,b,c,d in Laravel 4 verwenden möchten
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);
});
Incase you're Schleife die OR-Bedingungen, Sie don't brauchen die zweite $query-> wo aus den anderen Beiträgen (eigentlich ich don't glaube, Sie brauchen im Allgemeinen, Sie können nur orWhere in der verschachtelten wo wenn einfacher)
$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);
}
});