MySQL: объединение трех таблиц - как? - PullRequest
1 голос
/ 06 июня 2010

У меня есть следующий запрос в моем приложении. Это работает хорошо, но мне нужно также указать количество продуктов, связанных с каждым производителем.

Текущий запрос:

SELECT * FROM (`manufacturers`)
JOIN `languages` ON `manufacturers`.`lang` = `languages`.`id`
ORDER BY `languages`.`id` asc, `id` asc

Моя таблица продуктов выглядит следующим образом:

id    |    name    |    manufacturerid
0     |   Product1 |    0

Ответы [ 2 ]

3 голосов
/ 06 июня 2010
SELECT `manufacturers`.*, `languages`.*, COUNT(`products`.`id`) AS NumberOfProducts
FROM (`manufacturers`)
JOIN `languages` ON `manufacturers`.`lang` = `languages`.`id`
LEFT OUTER JOIN `products` ON 
      `products`.`manufacturerid` =  `manufacturers`.`manufacturerid`
GROUP BY <Column list for manufacturers AND languages here>
ORDER BY `languages`.`id` asc, `manufacturers`.`id` asc
3 голосов
/ 06 июня 2010
select * 
from `manufacturers` m
inner join `languages` l on m.`lang` = l.`id` 
left outer join (
    select manufacturerid, count(*) as ProductCount
    from Products
    group by manufacturerid
) pc on m.id = pc.manufacturerid
order by l.`id` asc, m.`id` asc 
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...