SQL – Nâng cao câu lệnh truy vấn qua FUNCTION, GROUP BY và ORDER BY (phần 4)

Với các kiến thức bài trước thì câu lệnh câu lệnh truy vấn cũng đã được hỗ trợ khá nhiều thứ như IN/EXISTS, LIKE, UNION và JOIN. Thì ở phần bài hôm nay, chúng ta cùng tiếp tục tìm hiểu các khái niệm khác, cũng sẽ hỗ trợ nhiều hơn cho câu lệnh truy vấn như là SQL FUNCTIONS, bộ đôi GROUP BY và HAVING, cuối cùng là ORDER BY.

1. Vai trò của FUNCTION, GROUP BY và ORDER BY trong SQL

Các từ khoá hôm nay cũng sẽ được sử dụng với câu lệnh SELECT để giúp truy xuất dữ liệu đa dạng hơn. Ta có thể thấy rõ ý nghĩa của các từ khoá này qua tên gọi của nó như FUNCTION là cách áp dụng hàm vào câu truy vấn, GROUP BY dùng để gộp nhóm các dòng dữ liệu, ORDER BY sử dụng để sắp xếp dữ liệu.

YouTube Video

[Database] DML 4 (Part 3)

YouTube Video

[Database] DML 4 (Part 2)

2. Ý nghĩa và cách sử dụng câu lệnh JOIN trong SQL

2.1. SQL FUNCTIONS

Mỗi DBMS sẽ có sư thay đổi về cú pháp SQL và bộ FUNCTIONS được sử dụng ở các SQL cũng sẽ có khác nhau đôi chút, hãy tham khảo FUNCTIONS ở MySQL:

https://www.w3schools.com/mysql/mysql_ref_functions.asp

Nếu bạn muốn sử dụng FUNCTION ở DBMS nào thì hãy tìm kiếm theo tên DBMS đó.

FUNCTION có 3 loại chính sau:

  • Dùng để xử lý chuỗi (String).
  • Dùng để xử lý số.
  • Thao tác với ngày, tháng, năm.
  • Và một số FUNCTION nâng cao.

Ví dụ

Muốn tính độ dài tên của mỗi bác sĩ.

SELECT last_name, CHAR_LENGTH(last_name)

FROM doctor;

Để liệt kê đầy đủ Họ và Tên các bác sĩ

SELECT CONCAT(first_name, ' ', middle_name, ' ', last_name) as full_name

FROM doctor;

2.2. Câu lệnh GROUP BY

Là câu lệnh để gộp nhóm các record có cùng giá trị column.

Thường được sử dụng chung với các hàm gộp (aggregate):

  • COUNT()
  • MAX()
  • MIN()
  • SUM()
  • AVG()

Cú pháp

SELECT column_name(s)

FROM table_name

WHERE condition

GROUP BY column_name(s)

ORDER BY column_name(s);

Ví dụ

Để lấy ra số lượng bác sĩ của mỗi chuyên khoa, thì thực hiện như bên dưới. Mình sử dụng GROUP BY để phân nhóm các bác sĩ cùng chuyên khoa, sau đó thực hiện đếm số lượng bác sĩ ở mỗi nhóm bằng cách dùng hàm COUNT.

SELECT specialization_id, COUNT(*)

FROM doctor

GROUP BY specialization_id;

2.3. Câu lệnh HAVING

Được sử dụng để chứa các điều kiện là hàm gộp.

Bởi vì WHERE không làm được điều này.

Cú pháp

SELECT column_name(s)

FROM table_name

WHERE condition

GROUP BY column_name(s)

HAVING condition

ORDER BY column_name(s);

Ví dụ

SELECT specialization_id, COUNT(*) quantity

FROM doctor

GROUP BY specialization_id

HAVING quantity >= 3;

Tiếp tục ví dụ ở phần 2, muốn lấy ra các chuyên khoa với nhiều hơn 3 bác sĩ thì kết hợp HAVING sau GROUP BY.

2.4. Câu lệnh ORDER BY

Câu lệnh để sắp xếp các records.

Với 2 điều kiện sắp xếp:

  • ASC: ascending (mặc định)
  • DESC: descending

Cú pháp

SELECT column1, column2, ...

FROM table_name

ORDER BY column1, column2, ... ASC|DESC;

Ví dụ

SELECT *

FROM doctor

ORDER BY date_of_birth DESC;

Câu lệnh trên dùng để lấy ra danh sách các bác sĩ theo thứ tự: ai lớn tuổi nhất thì hiển thị ra trước.

Kết luận

Với việc nắm được toàn bộ các câu lệnh được sử dụng với DML thì bạn có thể tự tin truy vấn thoải mái rồi, nếu phần nào chưa rõ thì có thể xem kĩ ở phần video.

https://ift.tt/6FqT3zU


Did you mean https://www.w3schools.cơm/mysql/mysql_ref_functions.asp


Nguồn: https://codegym.vn/blog/2023/11/20/truy-van-qua-function-group-by-va-order-by-phan-4/

Nhận xét

Bài đăng phổ biến