Я пытаюсь извлечь значения из базы данных для веб-приложения, где модератор может добавлять компании в список указанных отраслей. В этом запросе необходимо указать название каждой отрасли вместе с числом активных компаний в качестве обзора для модератора.
Это мои таблицы:
companies
____________________________________
| id | company | active |
|---------------------------|--------|
| 12 | Ton-o-Bricks Haulage | 0 |
| 16 | Roofs 'n' Walls | 1 |
| 23 | Handy Services | 1 |
| 39 | Carpentharry | 1 |
|---------------------------|--------|
industries
________________________
| id | industry | mod |
|------------------|-----|
| 2 | Roofing | 2 |
| 4 | Carpentry | 2 |
| 7 | Handyman | 2 |
| 8 | Haulage | 2 |
| 9 | Electrician | 2 |
|------------------|-----|
links
___________________________
| id | industry | company |
|--------------------------|
| 1 | 2 | 23 |
| 2 | 4 | 16 |
| 3 | 4 | 39 |
| 4 | 7 | 23 |
| 5 | 2 | 16 |
| 6 | 8 | 12 |
|--------------------------|
Этот запрос работает, но не учитывает неактивных компаний:
SELECT industries.id, industries.industry, count(links.id) as count FROM industries LEFT JOIN links on links.industry=industries.id WHERE industries.mod=2 GROUP BY industries.id
// -Results =======
2 Roofing 2
4 Carpentry 2
7 Handyman 1
8 Haulage 1
9 Electrician 0
Мне нужно, чтобы данные подсчитывались только для активных компаний , но при попытке получить странные результаты:
SELECT industries.id, industries.industry, count(links.id) as count FROM industries LEFT JOIN links on links.industry=industries.id, companies WHERE industries.mod=2 AND companies.active=1 GROUP BY industries.id
// -Results =======
2 Roofing 6
4 Carpentry 6
7 Handyman 3
8 Haulage 3
9 Electrician 0
Я знаю, что упускаю что-то простое, я просто не могу понять, что
Спасибо,
Стивен