PostgreSQL - AND & OR Clauses: A Beginner's Guide

Xin chào các bạn yêu thích cơ sở dữ liệu! Hôm nay, chúng ta sẽ bắt đầu một hành trình thú vị vào thế giới của PostgreSQL, đặc biệt tập trung vào các mệnh đề AND và OR. Những viên ngọc nhỏ này giống như muối và tiêu của việc truy vấn cơ sở dữ liệu - chúng có thể看起来 đơn giản, nhưng chúng có thể thêm rất nhiều hương vị cho việc truy xuất dữ liệu của bạn! Vậy, hãy cuộn lên tay áo và cùng nhau nhảy vào!

PostgreSQL - AND & OR Clauses

Hiểu về các phép toán liên hợp

Trước khi chúng ta đi vào chi tiết, hãy nói về các phép toán liên hợp là gì. Trong PostgreSQL (và SQL nói chung), các phép toán liên hợp được sử dụng để kết hợp nhiều điều kiện trong một mệnh đề WHERE. Chúng giúp chúng ta lọc dữ liệu chính xác hơn, cho phép chúng ta đặt những câu hỏi phức tạp hơn đối với cơ sở dữ liệu của mình.

Có hai phép toán liên hợp chính chúng ta sẽ khám phá hôm nay:

  1. AND
  2. OR

Hãy nghĩ về chúng như một cặp đôi động lực của việc lọc dữ liệu. Chúng cùng nhau (hoặc riêng lẻ) giúp bạn xác định chính xác thông tin bạn cần.

Phép toán AND

Hãy bắt đầu với phép toán AND. Đây là một công cụ nhỏ có sức mạnh lớn được sử dụng khi bạn muốn tất cả các điều kiện được chỉ định đều là đúng. Nó giống như nói, "Tôi muốn cái này VÀ cái kia VÀ cả cái khác nữa!"

Cú pháp

SELECT column1, column2, ...
FROM table_name
WHERE condition1 AND condition2 AND condition3 ...;

Ví dụ 1: Sử dụng cơ bản AND

Hãy tưởng tượng chúng ta có một bảng叫做 employees với các cột name, age, và department. Giả sử chúng ta muốn tìm tất cả các nhân viên trên 30 tuổi VÀ làm việc trong bộ phận IT.

SELECT name, age, department
FROM employees
WHERE age > 30 AND department = 'IT';

Truy vấn này sẽ trả về chỉ những nhân viên thỏa mãn cả hai điều kiện: họ phải trên 30 tuổi VÀ làm việc trong IT. Nếu một nhân viên 35 tuổi nhưng làm việc trong bộ phận Marketing, họ sẽ không xuất hiện trong kết quả của chúng ta.

Ví dụ 2: Nhiều điều kiện AND

Bây giờ, hãy làm cho nó phức tạp hơn một chút. Giả sử chúng ta muốn nhân viên trên 30 tuổi, làm việc trong IT, VÀ có thu nhập trên $75,000?

SELECT name, age, department, salary
FROM employees
WHERE age > 30 AND department = 'IT' AND salary > 75000;

Truy vấn này thêm một lớp lọc khác. Nó sẽ chỉ trả về nhân viên thỏa mãn tất cả ba tiêu chí. Nó giống như một câu lạc bộ VIP mà bạn cần phải thỏa mãn tất cả các yêu cầu để vào!

Phép toán OR

Bây giờ, hãy gặp phép toán OR. Đây là lựa chọn của bạn khi bạn muốn ít nhất một trong các điều kiện của mình là đúng. Nó giống như nói, "Tôi sẽ chọn cái này HOẶC cái kia HOẶC có lẽ cả cái khác."

Cú pháp

SELECT column1, column2, ...
FROM table_name
WHERE condition1 OR condition2 OR condition3 ...;

Ví dụ 3: Sử dụng cơ bản OR

Sử dụng bảng employees một lần nữa, giả sử chúng ta muốn tìm nhân viên dưới 25 tuổi HOẶC trên 50 tuổi.

SELECT name, age
FROM employees
WHERE age < 25 OR age > 50;

Truy vấn này sẽ trả về tất cả nhân viên dưới 25 tuổi hoặc trên 50 tuổi. Nó không quan trọng họ thỏa mãn điều kiện nào, miễn là họ thỏa mãn ít nhất một điều kiện.

Ví dụ 4: Nhiều điều kiện OR

Hãy làm cho nó thú vị hơn một chút. Giả sử chúng ta muốn nhân viên dưới 25 tuổi, trên 50 tuổi, HOẶC làm việc trong bộ phận Tài chính?

SELECT name, age, department
FROM employees
WHERE age < 25 OR age > 50 OR department = 'Finance';

Truy vấn này mở rộng phạm vi hơn. Nó sẽ trả về nhân viên trẻ, nhân viên lớn tuổi, và bất kỳ ai trong bộ phận Tài chính, bất kể tuổi tác của họ.

Kết hợp AND và OR

Bây giờ, hãy xem xét điều thú vị thực sự. Chúng ta có thể kết hợp các phép toán AND và OR để tạo ra các truy vấn phức tạp hơn. Nhưng hãy cẩn thận! Trật tự các phép toán quan trọng, giống như trong toán học.

Ví dụ 5: Kết hợp AND và OR

Giả sử chúng ta muốn nhân viên hoặc (dưới 25 tuổi và trong IT) HOẶC (trên 50 tuổi và trong bộ phận Tài chính).

SELECT name, age, department
FROM employees
WHERE (age < 25 AND department = 'IT') OR (age > 50 AND department = 'Finance');

Lưu ý các dấu ngoặc đơn? Chúng rất quan trọng. Chúng cho PostgreSQL biết để đánh giá những gì trong chúng trước, trước khi áp dụng phép toán OR.

Practices và Tips

  1. Sử dụng dấu ngoặc đơn: Khi kết hợp AND và OR, luôn sử dụng dấu ngoặc đơn để làm rõ ý định của bạn.
  2. Bắt đầu từ đơn giản: Xây dựng truy vấn của bạn từng bước. Bắt đầu với một điều kiện, sau đó thêm nhiều điều kiện hơn khi cần thiết.
  3. Kiểm tra, kiểm tra, kiểm tra: Luôn kiểm tra truy vấn của bạn với dữ liệu mẫu để đảm bảo chúng trả về những gì bạn mong đợi.

Bảng phương pháp phổ biến

Dưới đây là bảng tóm tắt các phương pháp phổ biến chúng ta đã thảo luận:

Phép toán Sử dụng Ví dụ
AND Tất cả các điều kiện phải đúng WHERE age > 30 AND department = 'IT'
OR Ít nhất một điều kiện phải đúng WHERE age < 25 OR age > 50
AND + OR Kết hợp nhiều điều kiện WHERE (age < 25 AND department = 'IT') OR (age > 50 AND department = 'Finance')

Kết luận

Và thế là bạn đã có nó, các bạn! Bạn vừa bước ra thế giới của các mệnh đề AND và OR trong PostgreSQL. Nhớ rằng, các phép toán này là những khối xây dựng của truy vấn cơ sở dữ liệu của bạn. Chúng có thể看起来 đơn giản, nhưng chúng rất mạnh mẽ khi được sử dụng đúng cách.

Trong hành trình PostgreSQL của bạn, bạn sẽ thấy mình sử dụng các phép toán này ngày càng nhiều. Chúng sẽ trở thành thói quen, giống như buộc dây giày hoặc đi xe đạp. Và trước khi bạn biết, bạn sẽ tạo ra các truy vấn phức tạp như một chuyên gia!

Vậy, hãy tiến lên và truy vấn! Thử nghiệm với các kết hợp khác nhau của AND và OR. Thử chúng trên dữ liệu của riêng bạn. Và quan trọng nhất, hãy vui vẻ với nó! Cuối cùng, không có gì thú vị hơn việc nhận được chính xác dữ liệu bạn cần với một truy vấn được tạo ra tốt.

Chúc các bạn truy vấn vui vẻ, và cho đến lần gặp lại, hãy để các liên kết của bạn nhanh chóng và các truy vấn của bạn tối ưu hóa!

Credits: Image by storyset