Trong bài này mình sẽ hướng dẫn cách sử dụng hàm CASE
trong MySQL
thông qua cú pháp và ví dụ thực tế.
1. Mô tả
Hàm CASE
có chức năng của câu lệnh IF-THEN-ELSE
bằng cách cho phép bạn đánh giá các điều kiện và trả về một giá trị khi điều kiện đầu tiên được đáp ứng.
2. Cú pháp
Cú pháp của hàm CASE
trong MySQL
là:
CASE [ expression ] WHEN condition_1 THEN result_1 WHEN condition_2 THEN result_2 ... WHEN condition_n THEN result_n ELSE result END
Trong đó:
Bài viết này được đăng tại [kiso.vn]
expression
: Không bắt buộc. Đó là giá trị mà bạn đang so sánh với danh sách các điều kiện. (ví dụ: condition_1, condition_2, … condition_n)condition_1, condition_2, ... condition_n
: Điều kiện theo thứ tự được liệt kê. Khi một điều kiện được tìm thấy là đúng, hàmCASE
sẽ trả về kết quả và không kiểm tra các điều kiện nữa.result_1, result_2, ... result_n
: Giá trị được trả về sau khi một điều kiện được tìm thấy là đúng.
Lưu ý:
- Nếu không có điều kiện nào là đúng, thì hàm
CASE
sẽ trả về giá trị trong mệnh đềELSE
. - Nếu mệnh đề
ELSE
bị bỏ qua và không có điều kiện nào được tìm thấy là đúng, thì câu lệnhCASE
sẽ trả về NULL.
3. Version
Hàm CASE
có thể được sử dụng trong các phiên bản sau của MySQL
:
- MySQL 5.7, MySQL 5.6, MySQL 5.5, MySQL 5.1, MySQL 5.0, MySQL 4.1, MySQL 4.0, MySQL 3.23.3
4. Ví dụ
SELECT diem, CASE quantity WHEN > 7 THEN 'Diem lon hon 7' WHEN = 7 THEN 'Diem bang 10' ELSE 'Diem nho hon 7' END FROM KetQua;
Bài viết liên quan
[CSF-2] Một số thiết lập CSF, LFD
Hôm nay mình sẽ thực hiện một số thiết lập trên CSF Mở file config để sửa đổi một số tính năng dưới /etc/csf/csf.conf Nội dung chính1. Mô tả2. Cú pháp3. Version4. Ví dụ1. Bảo...
[CSF-1] Tăng bảo mật Server với ConfigServer Firewall (CSF)
Nội dung chính1. Mô tả2. Cú pháp3. Version4. Ví dụ1. Khái niệm CSF: CSF (ConfigServer & Firewall) là một bộ ứng dụng hoạt động trên Linux như một firewall được phát hành miễn phí để...
Sử dụng SSH Key với Gitlab và Github
Bài viết này mình sẽ hướng dẫn các bạn tạo ssh key cho Gitlab và Github SSH là gì? Secure Socket Shell là một giao thức mạng dùng để thiết lập kết nối mạng một...
Directory traversal vulnerabilities (phần 4)
Nội dung chính1. Mô tả2. Cú pháp3. Version4. Ví dụV. Phân tích và khai thác các lỗ hổng Directory traversal (tiếp) 5. Bypass lỗ hổng khi trang web sử dụng đường dẫn đầy đủ Xét...
Directory traversal vulnerabilities (phần 3)
Nội dung chính1. Mô tả2. Cú pháp3. Version4. Ví dụV. Phân tích và khai thác các lỗ hổng Directory traversal 1. Lỗ hổng xảy ra khi sử dụng các hàm đọc file và tin tưởng...
Directory traversal vulnerabilities (phần 2)
Nội dung chính1. Mô tả2. Cú pháp3. Version4. Ví dụIII. Vì sao lỗ hổng Directory traversal xuất hiện? Với mỗi ngôn ngữ lập trình khác nhau, điểm xuất hiện các lỗ hổng Directory traversal cũng...