Мітки рядків MySQL з іншої таблиці для кожного запису в таблиці


21
SELECT
  student.StudentID,
  student.`Name`,
  COUNT(attendance.AttendanceID) AS Total
FROM
  student
LEFT JOIN attendance ON student.StudentID = attendance.StudentID

Я намагаюся підрахувати останній рядок, але замість цього він підраховує всі результати та повертає один результат

Я отримую щось на кшталт

введіть тут опис зображення

так як є кілька записів, оскільки в ідентифікаторі відвідувачів для K1052280 є дві записи, я хочу їх порахувати і повернути номер. Щось на зразок

введіть тут опис зображення

Відповіді:


24

Ви просто пропустили групу BY

ВАШ ЗАПИТАННЯ З ГРУПАМИ

SELECT
  student.StudentID,
  student.`Name`,
  COUNT(attendance.AttendanceID) AS Total
FROM
  student
LEFT JOIN attendance ON student.StudentID = attendance.StudentID
GROUP BY student.StudentID,student.`Name`;

ДАНІ ЗРАЗУ

DROP DATABASE IF EXISTS alishaikh; CREATE DATABASE alishaikh;
USE alishaikh
CREATE TABLE student
(
  StudentID CHAR(8) NOT NULL,
  Name VARCHAR(40),
  PRIMARY KEY (StudentID)
);
INSERT INTO student (StudentID,Name) VALUES
('k1052280','Ali Shaikh'),('k1052287','McKenzie Roth'),
('k1052288','Dacey Sullivan'),('k1052294','Zelda Cantu'),
('k1052295','Kimberly Melton'),('k1052296','Tatianna Cantrell'),
('k1052297','Morgan Thornton'),('k1052298','Allistair Barlow'),
('k1052299','Troy Fulton');
CREATE TABLE attendance
(
  AttendanceID INT NOT NULL AUTO_INCREMENT,
  StudentID CHAR(8) NOT NULL,
  PRIMARY KEY (AttendanceID),
  KEY (StudentID)
);
INSERT INTO attendance (StudentID) VALUES
('k1052280'),('k1052280'),('k1052287'),('k1052287'),
('k1052288'),('k1052295'),('k1052295'),('k1052295');

ЗРАЗОВАНІ ДАНІ ЗАВАНТАЖЕНІ

mysql> DROP DATABASE IF EXISTS alishaikh; CREATE DATABASE alishaikh;
Query OK, 2 rows affected (0.01 sec)
Query OK, 1 row affected (0.00 sec)
mysql> USE alishaikh
Database changed
mysql> CREATE TABLE student
    -> (
    ->   StudentID CHAR(8) NOT NULL,
    ->   Name VARCHAR(40),
    ->   PRIMARY KEY (StudentID)
    -> );
Query OK, 0 rows affected (0.03 sec)

mysql> INSERT INTO student (StudentID,Name) VALUES
    -> ('k1052280','Ali Shaikh'),('k1052287','McKenzie Roth'),
    -> ('k1052288','Dacey Sullivan'),('k1052294','Zelda Cantu'),
    -> ('k1052295','Kimberly Melton'),('k1052296','Tatianna Cantrell'),
    -> ('k1052297','Morgan Thornton'),('k1052298','Allistair Barlow'),
    -> ('k1052299','Troy Fulton');
Query OK, 9 rows affected (0.00 sec)
Records: 9  Duplicates: 0  Warnings: 0

mysql> CREATE TABLE attendance
    -> (
    ->   AttendanceID INT NOT NULL AUTO_INCREMENT,
    ->   StudentID CHAR(8) NOT NULL,
    ->   PRIMARY KEY (AttendanceID),
    ->   KEY (StudentID)
    -> );
Query OK, 0 rows affected (0.02 sec)

mysql> INSERT INTO attendance (StudentID) VALUES
    -> ('k1052280'),('k1052280'),('k1052287'),('k1052287'),
    -> ('k1052288'),('k1052295'),('k1052295'),('k1052295');
Query OK, 8 rows affected (0.00 sec)
Records: 8  Duplicates: 0  Warnings: 0

ВАШ ЗАПИТАННЯ З ГРУПАМИ ВИКОНАНИМ

mysql> SELECT
    ->   student.StudentID,
    ->   student.`Name`,
    ->   COUNT(attendance.AttendanceID) AS Total
    -> FROM
    ->   student
    -> LEFT JOIN attendance ON student.StudentID = attendance.StudentID
    -> GROUP BY student.StudentID,student.`Name`;
+-----------+-------------------+-------+
| StudentID | Name              | Total |
+-----------+-------------------+-------+
| k1052280  | Ali Shaikh        |     2 |
| k1052287  | McKenzie Roth     |     2 |
| k1052288  | Dacey Sullivan    |     1 |
| k1052294  | Zelda Cantu       |     0 |
| k1052295  | Kimberly Melton   |     3 |
| k1052296  | Tatianna Cantrell |     0 |
| k1052297  | Morgan Thornton   |     0 |
| k1052298  | Allistair Barlow  |     0 |
| k1052299  | Troy Fulton       |     0 |
+-----------+-------------------+-------+
9 rows in set (0.00 sec)

mysql>

СПРОБУВАТИ !!!


Дякую за це чітке пояснення. Тепер ще одне питання. Як можна сортувати таблицю за загальним або відфільтрувати записи, де Total = 0?
Zonker.in.Geneva

додати order by Totalпісля групи від
ПСН

@PSN Дякуємо за нагадування. У більшості випадків GROUP BYвстановлюється значення за замовчуванням для ORDER BY. Іноді це не так. Отже, ORDER BYтакож можна було б використовувати !!!
RolandoMySQLDBA

@RolandoMySQLDBA, вибачте, що зачепився за цю зрозумілу відповідь, сподіваючись на вирішення мого питання! Зробимо вигляд, що є третя таблиця TestResultзі стовпцями (StudentID, Result). Я також хотів би приєднатися TestResultі, врешті-решт, отримати COUNT(TestResult.Result)кожного студента. Чомусь я отримую зайві значення для COUNT, а під час використання підзапитів повертає правильні COUNT.
Іфєді Оконкво

Щоб уточнити, мій запит такий: stackoverflow.com/a/24727261/2554788 , але без DISTINCTключових слів. Що може бути причиною повернення COUNT-файлів дещо іншим (як правило, вищим, і, звичайно, неправильним), ніж шаблон запиту?
Іфєді Оконкво
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.