×

Tạo điều kiện phủ định với NOT trong MySQL

Trong môi trường cơ sở dữ liệu, việc tìm kiếm dữ liệu không khớp với điều kiện cụ thể là điều vô cùng quan trọng và cần thiết. Trong MySQL, chúng ta có thể sử dụng từ khóa NOT để phủ định các điều kiện trong các câu lệnh SQL. Bài viết này sẽ giúp bạn hiểu rõ hơn về việc sử dụng NOT trong MySQL qua các ví dụ thực tiễn.

1. Sử Dụng NOT Với Điều Kiện WHERE

Một trong những cách phổ biến nhất để sử dụng NOT là kết hợp với câu lệnh WHERE. Ví dụ, giả sử bạn có một bảng tên là NHANVIEN với các cột như ID, TEN, VAITRO. Bạn muốn tìm tất cả các nhân viên không phải là 'Quản lý'. Câu lệnh sẽ như sau:

SELECT * FROM NHANVIEN WHERE VAITRO <> 'Quản lý';

Hoặc, bạn có thể sử dụng NOT để đạt được cùng mục đích:

SELECT * FROM NHANVIEN WHERE NOT VAITRO = 'Quản lý';

2. Kết Hợp NOT Với Các Toán Tử Logic

MySQL cho phép bạn sử dụng NOT trong sự kết hợp với các toán tử logic khác như AND và OR để tạo ra các điều kiện phức tạp hơn. Giả sử bạn muốn tìm các nhân viên không phải là 'Quản lý' hoặc không làm việc tại 'Phòng Kế Toán', câu lệnh sẽ như sau:

SELECT * FROM NHANVIEN WHERE NOT (VAITRO = 'Quản lý' OR PHONG = 'Phòng Kế Toán');

Hoặc nếu bạn muốn tìm các nhân viên không phải là 'Quản lý' và cũng không làm việc tại 'Phòng Kế Toán':

SELECT * FROM NHANVIEN WHERE NOT VAITRO = 'Quản lý' AND NOT PHONG = 'Phòng Kế Toán';

3. Sử Dụng NOT Với IS NULL

Khi làm việc với các giá trị NULL trong MySQL, NOT cũng thực sự hữu ích. Ví dụ, nếu bạn muốn tìm các bản ghi mà giá trị của cột EMAIL không bị bỏ trống:

SELECT * FROM NHANVIEN WHERE EMAIL IS NOT NULL;

4. Sử Dụng NOT Với IN

Từ khóa IN giúp bạn kiểm tra xem một giá trị có nằm trong một danh sách các giá trị nào đó không. Kết hợp NOT với IN sẽ giúp bạn tìm các giá trị không nằm trong danh sách. Giả sử bạn muốn tìm các nhân viên mà vai trò của họ không thuộc 'Quản lý', 'Kế toán' và 'Nhân sự':

SELECT * FROM NHANVIEN WHERE VAITRO NOT IN ('Quản lý', 'Kế toán', 'Nhân sự');

5. Sử Dụng NOT Với LIKE

LIKE là từ khóa dùng để kiểm tra một chuỗi con có xuất hiện trong một chuỗi khác hay không. Khi kết hợp với NOT, nó sẽ kiểm tra các chuỗi không khớp với mẫu đó. Ví dụ, muốn tìm tất cả các nhân viên mà tên của họ không bắt đầu bằng chữ 'A':

SELECT * FROM NHANVIEN WHERE TEN NOT LIKE 'A%';

6. Kết Hợp NOT Với EXISTS

EXISTS là một từ khóa dùng để kiểm tra sự tồn tại của một hàng nào đó trong một truy vấn con (subquery). Kết hợp NOT với EXISTS sẽ kiểm tra việc không tồn tại. Ví dụ, bạn muốn tìm tất cả các nhân viên không thuộc bất kỳ dự án nào:

SELECT * FROM NHANVIEN WHERE NOT EXISTS (SELECT * FROM DUAN WHERE DUAN.NHANVIENID = NHANVIEN.ID);

Kết Luận

Sử dụng NOT trong MySQL là một cách hiệu quả để loại trừ các điều kiện không mong muốn trong các truy vấn của bạn. Bằng cách hiểu rõ và áp dụng đúng cách. bạn có thể tối ưu hóa các truy vấn SQL để lấy dữ liệu chính xác và hữu ích hơn. Hãy thử áp dụng các cách sử dụng NOT đã được trình bày ở trên vào các bài toán thực tế của bạn để thấy được sự khác biệt.

Comments