it-swarm-eu.dev

Come combinare AND e OR nella clausola WHERE utilizzando un oggetto query?

Dato l'SQL desiderato di seguito, dove Cond1 e Cond2 devono essere soddisfatti [~ # ~] o [~ # ~ ] Cond3 deve essere soddisfatto per la selezione, qual è il modo corretto di usare getQuery() per raggiungerlo?

SQL desiderato: Condizione1 e Condizione2 tra parentesi)

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

Con Concatenamento: specificando OR in -> where ()

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

SQL risultante: (SQL tra parentesi mancanti)

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

With Arrays specificando OR nel -> where ()

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

SQL risultante: (SQL tra parentesi mancanti)

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

Incluse le parentesi che sono necessarie, con Chaining, ha prodotto l'SQL desiderato:

Con Concatenamento: specificando OR e racchiudendo Cond1/2 tra parentesi

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

SQL risultante: (include parentesi)

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

OPPURE usa oWhere/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'));
20
GDP