Назад к вопросам
Иннотех
Middle+
6
table student id PK name faculty_id table faculty id PK name SELECT f.name, count(*) FROM faculty f JOIN student s ON s.faculty_id = f.id GROUP BY f.id, f.name GROUP BY /*f.id,*/ f.name GROUP BY f.id/*, f.name*/
Компании, где спрашивали
Ответ от нейросети
sobes.tech AI
В SQL запросе с использованием JOIN и GROUP BY важно правильно группировать данные.
В данном случае:
SELECT f.name, count(*)
FROM faculty f
JOIN student s ON s.faculty_id = f.id
GROUP BY f.id, f.name
группировка по f.id, f.name корректна, так как f.id — первичный ключ, а f.name — атрибут, связанный с ним.
Если попытаться группировать только по f.name, то возможна ошибка или некорректный результат, если имена факультетов не уникальны.
Группировка только по f.id тоже корректна, так как id уникален, и можно выбрать f.name без группировки, если СУБД это позволяет.
Итог: для правильного подсчёта студентов на факультет лучше группировать по f.id (уникальному идентификатору).