Đối với điều này, hãy sử dụng mệnh đề GROUP BY HAVING.
Đầu tiên chúng ta hãy tạo một bảng -
mysql> create table DemoTable782 ( Name varchar(100), Score int ); Query OK, 0 rows affected (1.18 sec)
Chèn một số bản ghi vào bảng bằng lệnh chèn -
mysql> insert into DemoTable782 values('John',156); Query OK, 1 row affected (0.18 sec) mysql> insert into DemoTable782 values('Carol',250); Query OK, 1 row affected (0.15 sec) mysql> insert into DemoTable782 values('Bob',140); Query OK, 1 row affected (0.17 sec) mysql> insert into DemoTable782 values('John',126); Query OK, 1 row affected (0.29 sec) mysql> insert into DemoTable782 values('John',140); Query OK, 1 row affected (0.17 sec) mysql> insert into DemoTable782 values('Bob',280); Query OK, 1 row affected (0.17 sec) mysql> insert into DemoTable782 values('Bob',250); Query OK, 1 row affected (0.41 sec) mysql> insert into DemoTable782 values('Carol',189); Query OK, 1 row affected (0.17 sec) mysql> insert into DemoTable782 values('Carol',299); Query OK, 1 row affected (0.21 sec)
Hiển thị tất cả các bản ghi từ bảng bằng câu lệnh select -
mysql> select *from DemoTable782;
Điều này sẽ tạo ra kết quả sau -
+-------+-------+ | Name | Score | +-------+-------+ | John | 156 | | Carol | 250 | | Bob | 140 | | John | 126 | | John | 140 | | Bob | 280 | | Bob | 250 | | Carol | 189 | | Carol | 299 | +-------+-------+ 9 rows in set (0.00 sec)
Sau đây là truy vấn để nhóm theo cột và hiển thị tổng các giá trị tương tự -
mysql> select Name,SUM(Score) AS Total from DemoTable782 group by Name HAVING Total > 500;
Điều này sẽ tạo ra kết quả sau -
+-------+-------+ | Name | Total | +-------+-------+ | Carol | 738 | | Bob | 670 | +-------+-------+ 2 rows in set (0.00 sec)