Chcę otrzymywać nazwę nieruchomości oraz liczbę jednostek i liczbę odrysowań. Mam to zapytanie:Double LEFT DOŁĄCZ
SELECT
`property`.`property_name`,
COUNT(unit_id) AS `units_count`,
COUNT(special_id) AS `specials_count`
FROM `property`
LEFT JOIN `property_unit` ON unit_property_id = property_id
LEFT JOIN `property_special` ON special_property_id = property_id
WHERE (property_id = '1')
GROUP BY `property_id`
ORDER BY `property_name` ASC
Ale nie działa poprawnie. Jeśli mam jeden z tych lewej dołącza - to ok, ale jeśli mam dwie, otrzymuję ten wynik:
Ilość["property_name"] => string(11) "Rivers Edge"
["units_count"] => string(1) "2"
["specials_count"] => string(1) "2"
Specials jest 2 i units_count wynosi 2, ale liczba jednostek jest naprawdę „1”. Jak mogę uzyskać dla niego poprawne liczby?
PS: dla tych, którzy wiedzą, Zend Framework:
$select->setIntegrityCheck(FALSE)
->from(
'property',
array(
'property_name',
)
)
->joinLeft(
'property_unit',
'unit_property_id = property_id',
array(
'units_count' => 'COUNT(unit_id)'
)
)
->joinLeft(
'property_special',
'special_property_id = property_id',
array(
'specials_count' => 'COUNT(special_id)'
)
)
->group('property_id')
->order('property_name');
Czy unikalne klucze unit_id i special_id znajdują się w tabelach property_unit i property_special? –
@ Mark Bannister Tak –