Mệnh đề HAVING trong SQL
Mệnh đề HAVING trong SQL được sử dụng để lọc các bản ghi và chỉ lấy những bản ghi phù hợp với yêu cầu hoặc thực sự cần thiết tương tự như mệnh đề WHERE. Tuy nhiên:
- WHERE là câu lệnh điều kiện trả kết quả đối chiếu với từng dòng.
- HAVING là câu lệnh điều kiện trả kết quả đối chiếu cho nhóm được tạo bởi mệnh đề GROUP BY.
Vì vậy mà sau GROUP BY thì sẽ chỉ dùng được HAVING còn WHERE không dùng được sau GROUP BY.
Cú pháp sử dụng HAVING trong SQL
Vị trí của mệnh đề HAVING trong một truy vấn SQL như sau:
SELECTFROMWHEREGROUP BYHAVINGORDER BY
Lưu ý: Mệnh đề HAVING phải theo sau mệnh đề GROUP BY trong một truy vấn và đặt trước mệnh đề ORDER BY nếu được sử dụng.
Dưới đây là cú pháp của lệnh SELECT bao gồm mệnh đề HAVING:
SELECT cot1, cot2FROM bang1, bang2WHERE [ dieu_kien ]GROUP BY cot1, cot2HAVING [ dieu_kien ]ORDER BY cot1, cot2
Ví dụ về HAVING trong SQL
Giả sử bảng NHANVIEN có các bản ghi như sau:
+----+----------+-----+-----------+----------+ | ID | TEN |TUOI | DIACHI | LUONG | +----+----------+-----+-----------+----------+ | 1 | Thanh | 32 | Haiphong | 2000.00 | | 2 | Loan | 25 | Hanoi | 1500.00 | | 3 | Nga | 23 | Hanam | 2000.00 | | 4 | Manh | 25 | Hue | 6500.00 | | 5 | Huy | 27 | Hatinh | 8500.00 | | 6 | Cao | 22 | HCM | 4500.00 | | 7 | Lam | 24 | Hanoi | 10000.00 | +----+----------+-----+-----------+----------+
Để hiển thị bản ghi có độ tuổi xuất hiện lớn hơn hoặc bằng 2 lần, ta chạy lệnh như sau:
SQL > SELECT ID, TEN, TUOI, DIACHI, LUONGFROM NHANVIENGROUP BY tuoiHAVING COUNT(tuoi) >= 2;
Kết quả trả về là:
+----+----------+-----+-----------+----------+ | ID | TEN |TUOI | DIACHI | LUONG | +----+----------+-----+-----------+----------+ | 2 | Loan | 25 | Hanoi | 1500.00 | +----+----------+-----+-----------+----------+
Trong phần tiếp theo, chúng ta sẽ tìm hiểu về Transaction trong SQL, các bạn nhớ theo dõi nhé.
Bạn nên đọc
Theo Nghị định 147/2024/ND-CP, bạn cần xác thực tài khoản trước khi sử dụng tính năng này. Chúng tôi sẽ gửi mã xác thực qua SMS hoặc Zalo tới số điện thoại mà bạn nhập dưới đây:
Cũ vẫn chất
-

Cách dùng biểu tượng cảm xúc trong Đấu Trường Chân Lý
3 ngày -

Cách đổi mật khẩu truy cập Ultraviewer
3 ngày -

19/5 là ngày gì? Ngày 19 tháng 5 năm 1890 là ngày gì?
3 ngày 6 -

Cách chạy ứng dụng Windows trên Android bằng Winlator
3 ngày -

5 cách lấy kim cương miễn phí trong Free Fire
3 ngày 3 -

Code Sự tiến hóa tối thượng: Saiyan mới nhất và cách nhập code
3 ngày -

Proxy và VPN khác gì nhau?
3 ngày -

Code Fairy Tail Fierce Fight mới nhất và cách nhập code
3 ngày -

Lời chúc Tết Đoan ngọ mùng 5/5 âm lịch, thơ hay về Tết Đoan Ngọ
3 ngày 1 -

Hướng dẫn nâng cấp nhóm Zalo lên cộng đồng
3 ngày
Hướng dẫn AI
Học IT
AI
Hàm Excel