Принимая во внимание требуемый SQL ниже, где должны быть соблюдены Cond1 и Cond2 ИЛИ Cond3 должен быть соблюден для выбора, какой правильный способ использовать getQuery()
для его достижения?
Требуемый SQL: Condition1 и Condition2 в скобках)
SELECT * FROM #__myTable
WHERE (condition1=true AND condition2=true) OR condition3=true
С цепочкой: указав ИЛИ в -> где ()
$query = $db->getQuery(true);
$query->select('* FROM #__myTable')
->where('condition1 = true AND condition2 = true','OR')
->where('condition3 = true');
Результирующий SQL: (в SQL отсутствуют скобки)
SELECT * FROM scm_myTable
WHERE condition1 = true AND condition2 = true OR condition3 = true
С Массивами, указывающими ИЛИ в -> где ()
$query = $db->getQuery(true);
$conditions12 = array(
'condition1 = true',
'condition2 = true'
);
$conditions3 = array(
'condition3 = true'
);
$query->select('* FROM #__myTable')
->where($conditions12, 'OR')
->where($conditions3);
Результирующий SQL: (в SQL отсутствуют скобки)
SELECT * FROM scm_myTable
WHERE condition1 = true OR condition2 = true OR condition3 = true