Consulta elocuente de Laravel: ¿Usar DÓNDE con O Y O?

Resuelto Farzher asked hace 54 años • 16 respuestas

Cómo digoWHERE (a = 1 OR b =1 ) AND (c = 1 OR d = 1)

Para consultas más complicadas, ¿se supone que debo usar SQL sin formato?

Farzher avatar Jan 01 '70 08:01 Farzher
Aceptado

Utilice la agrupación lógica (Laravel 7.x / 4.2 ). Para tu ejemplo, sería algo como esto:

Model::where(function ($query) {
    $query->where('a', '=', 1)
          ->orWhere('b', '=', 1);
})->where(function ($query) {
    $query->where('c', '=', 1)
          ->orWhere('d', '=', 1);
});
rmobis avatar Jun 08 '2013 01:06 rmobis

Si desea utilizar 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);
});
Yilmazerhakan avatar Mar 04 '2014 13:03 Yilmazerhakan

En caso de que estés repitiendo las condiciones OR, no necesitas la segunda consulta $->dónde de las otras publicaciones (en realidad, no creo que la necesites en general, puedes usar orWhere en el dónde anidado, si es 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);
    }
});
Sabrina Leggett avatar Apr 01 '2015 14:04 Sabrina Leggett

si desea usar paréntesis en laravel 4 y no olvide regresar.
En Laravel 4 (al menos) necesita usar $a, $b entre paréntesis como en el ejemplo.

$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);
});

Este es mi resultado: ingrese la descripción de la imagen aquí

Samrong Prey Kabbas avatar Sep 13 '2015 06:09 Samrong Prey Kabbas

Simplemente use en 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();

Producirá una consulta como:

SELECT * FROM <table> WHERE (a='foo' or b='bar') AND (c='john' or d='doe');
Md. Saidur Rahman Milon avatar Dec 23 '2017 19:12 Md. Saidur Rahman Milon