Como combinar ANDs e ORs na cláusula WHERE usando um Objeto de Consulta?


21

Dado o SQL desejado abaixo, onde Cond1 e Cond2 devem ser atendidos OU Cond3 deve ser atendido para seleção, qual é a maneira correta de usar getQuery()para alcançá-lo?

SQL desejado: Condição1 e Condição2 entre parênteses)

SELECT * FROM #__myTable 
WHERE (condition1=true AND condition2=true) OR condition3=true

Com encadeamento: especificando OR no -> onde ()

$query = $db->getQuery(true);
$query->select('* FROM #__myTable')
->where('condition1 = true AND condition2 = true','OR')
->where('condition3 = true');

SQL resultante: (o SQL está faltando parênteses)

SELECT * FROM scm_myTable
WHERE condition1 = true AND condition2 = true OR condition3 = true

Com matrizes especificando OR no -> onde ()

$query = $db->getQuery(true);
$conditions12 = array(
    'condition1 = true',
    'condition2 = true'
);
$conditions3 = array(
    'condition3 = true'
);
$query->select('* FROM #__myTable')
->where($conditions12, 'OR')
->where($conditions3);

SQL resultante: (o SQL está faltando parênteses)

SELECT * FROM scm_myTable
WHERE condition1 = true OR condition2 = true OR condition3 = true

Respostas:


20

A inclusão dos parênteses necessários, com o encadeamento, produziu o SQL desejado:

Com encadeamento: especificando OR e envolvendo Cond1 / 2 entre parênteses

$query = $db->getQuery(true);
$query->select('* FROM #__myTable')
->where('(condition1 = true AND condition2 = true)','OR')
->where('condition3 = true');

SQL resultante: (inclui parênteses)

SELECT * FROM scm_myTable
WHERE (condition1 = true AND condition2 = true) OR condition3 = true

OU use orWhere / andWhere

$query = $db->getQyery(true);
$query->select('*')
->from($db->quoteName('#__myTable'))
->where($db-quoteName('condition3') . ' = TRUE')
->orWhere(array($db->quoteName('condition1') . ' = TRUE', $db->quoteName('condition2') . ' = TRUE'));
Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.