Как выбрать данные из двух таблиц с использованием count() mysql ???

программирование php MySQL базы данных sql

Есть две таблицы:

site и extension. Они связаны по site_id. мне нужно выбрать урл сайта и его айди из site, а также кол-во расширений для каждого сайта из extension. Новыбрать нужно только те сайты, которые содержат расширение в extension, например, с именем PORSCHE.

Запрос вида: SELECT site.site_id, site.url, count(extension.ext_id) as count FROM site LEFT JOIN extension ON extension.site_id=site.site_id WHERE extension.name='porsche' GROUP BY site.site_id
вывод столько урлов, сколько удовлетворяет условию where, но количество пишет везде равное 1.

Помогите пожалуйста решить проблему.
Ответы:
замените count(extension.ext_id) as count на подзапрос
select site.site_id,site.url,count(extension.ext_id) as count from site left join extension on extension.site_id=site.site_id group by site.site_id having max(extension.name='porsche')


12 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.