Chức năng:
Gom nhóm các dòng dữ liệu theo tiêu chí gom nhóm đặt trong mệnh đề GROUP BY nhằm hỗ trợ và phục vụ các mục đích của câu truy vấn.
Cú pháp:
SELECT [DISTINCT] *|DANH_SACH_THUOC_TINH|BIEU_THUC,...
FROM DANH_SACH_QUAN_HE
[WHERE BIEU_THUC_DIEU_KIEN]
GROUP BY DANH_SACH_THUOC_TINH
Trong đó:
+ DANH_SACH_THUOC_TINH: bao gồm tất cả các cột muốn rút trích thông tin từ quan hệ trong cơ sở dữ liệu. Các thuộc tính cách nhau bởi dấu ",". Các thuộc tính trùng tên phải đặt tên quan hệ gắn liền với thuộc tính đó (theo quy tắc TEN_QUAN_HE.TEN_THUOC_TINH).
+ DANH_SACH_QUAN_HE: bao gồm tất cả các quan hệ tham gia hỗ trợ thực hiện yêu cầu truy vấn. Các quan hệ cách nhau bởi dấu ",".
+ BIEU_THUC_DIEU_KIEN: các dòng dữ liệu được rút trích ra từ cơ sở dữ liệu phải thỏa mãn các biểu thức điều kiện đã được quy định trong mệnh đề WHERE. Các điều kiện được nối với nhau bởi AND/OR.
+ Mệnh đề GROUP BY: danh sách các thuộc tính được chọn làm tiêu chí gom nhóm. Tất cả các thuộc tính đơn lẻ (ngoại trừ các hàm kết hợp và gom nhóm) xuất hiện trong mệnh đề SELECT phải đặt vào GROUP BY.
Ví dụ minh họa
Để thuận tiện cho các bạn học tập, mình có tạo sẵn file .sql trong này đã mình tạo cấu trúc bảng và data sẵn để các bạn dễ dàng thực hiện truy vấn, các bạn có thể tải tại đây.
Ví dụ 1: Hãy cho biết số lượng nhân viên của từng phòng.
SELECT PHG, COUNT(MANV) AS 'SLNV'
FROM NHANVIEN
GROUP BY PHG
Kết quả:
Ví dụ 2: Hãy cho biết tên phòng cùng số lượng nhân viên của từng phòng.
SELECT TENPHG, COUNT(MANV) AS 'SLNV'
FROM NHANVIEN, PHONGBAN
WHERE PHG = MAPHG
GROUP BY PHG, TENPHG
Kết quả: