Thứ Hai, 24 tháng 7, 2023

Tìm hiểu Subquery trong Oracle

Trong bài viết này chúng ta sẽ tìm hiểu một phần khá hay đó là subquery trong Oracle. Subquery hay còn gọi là truy vấn con, nghĩa là bạn sẽ tạo ra những truy vấn nhỏ để đưa nó vào truy vấn cha.

Mục lục

  • 1. Subquery trong Oracle
  • 2. Một vài ví dụ Subquery trong Oracle
    • Sử dụng ở FROM
    • Sử dụng ở WHERE
    • Sử dụng ở SELECT
    • Nested Subquery
  • 3. Lời kết

1. Subquery trong Oracle

Như các bạn biết lệnh SELECT sẽ trả về một bảng dữ liệu mới, bảng này sẽ không lưu vào hệ thống mà là một bảng tạm (local temporary) và sẽ tự giải phóng khi câu truy vấn kết thúc. Như vậy ta hoàn toàn có thể thực hiện một truy vấn trên bảng kết quả đó, và ta chỉ thực hiện được truy vấn tìm kiếm trên nó mà thôi.

Ví dụ: Tìm nhân viên có mức lương cao nhất

1
2
3
4
5
6
7
SELECT *
FROM employees
WHERE salary =
(
    SELECT max(salary)
    FROM employees
);

Ở lệnh truy vấn con sẽ trả về row có mức lương cao nhất, sau đó sẽ thực hiện so sánh ở truy vấn cha và đưa ra kết quả chính xác.

Đây chỉ là một ví dụ giúp các bạn hiểu, chứ thực tế bài này bạn không nên sử dụng subquery vì sẽ không tối ưu.

2. Một vài ví dụ Subquery trong Oracle

Dưới đây sẽ là một vài ví dụ, mình sẽ không giải thích ý nghĩa của từng lệnh mà thay vào đó bạn hãy tự đọc và suy ngẫm nhé.

Sử dụng ở FROM

1
2
3
4
5
6
7
SELECT count(*)
FROM
(
    SELECT *
    FROM employees
    WHERE last_name LIKE 'A%'
);

Sử dụng ở WHERE

1
2
3
4
5
6
7
SELECT *
FROM employees e1
WHERE e1.salary = (
    SELECT max(salary)
    FROM employees e2
    WHERE e1.department_id = e2.department_id
);

Sử dụng ở SELECT

1
2
3
4
5
SELECT (
    SELECT avg(salary)
    FROM employees) AS avg_sal,
    salary
FROM employees;

Nested Subquery

Nested subquery tức là bạn sử dụng nhiều lệnh truy vấn con trong một lệnh cha.

1
2
3
4
5
6
7
8
9
10
SELECT count(*)
FROM
(
    SELECT salary,
        (
            SELECT avg(salary)
            FROM employees) avg_sal
    FROM employees
)
WHERE salary > avg_sal;

Oracle chỉ cho phép bạn sử dụng 255 cấp truy vấn con, một con số không ai sử dụng hết được :)

3. Lời kết

Nếu một bài toán có thể giải quyết được ở cách thông thường mà không cần sử dụng subquery thì bạn nên dùng cách thông thường nhé, bởi subquery sẽ tốn nhiều tài nguyên hơn.

Bài này đã hướng dẫn bạn subquery và gì và cách sử dụng trong Oracle, hẹn gặp lại các bạn ở bài tiếp theo.

=============================
* KHOÁ HỌC ORACLE DATABASE A-Z ENTERPRISE trực tiếp từ tôi giúp bạn bước đầu trở thành những chuyên gia DBA, đủ kinh nghiệm đi thi chứng chỉ OA/OCP, đặc biệt là rất nhiều kinh nghiệm, bí kíp thực chiến trên các hệ thống Core tại VN chỉ sau 1 khoá học.
* CÁCH ĐĂNG KÝ: Gõ (.) hoặc để lại số điện thoại hoặc inbox https://m.me/tranvanbinh.vn hoặc Hotline/Zalo 090.29.12.888
* Chi tiết tham khảo:
https://bit.ly/oaz_w
=============================
KẾT NỐI VỚI CHUYÊN GIA TRẦN VĂN BÌNH:
📧 Mail: binhoracle@gmail.com
☎️ Mobile/Zalo: 0902912888
👨 Facebook: https://www.facebook.com/BinhOracleMaster
👨 Inbox Messenger: https://m.me/101036604657441 (profile)
👨 Fanpage: https://www.facebook.com/tranvanbinh.vn
👨 Inbox Fanpage: https://m.me/tranvanbinh.vn
👨👩 Group FB: https://www.facebook.com/groups/DBAVietNam
👨 Website: https://www.tranvanbinh.vn
👨 Blogger: https://tranvanbinhmaster.blogspot.com
🎬 Youtube: https://www.youtube.com/@binhguru
👨 Tiktok: https://www.tiktok.com/@binhguru
👨 Linkin: https://www.linkedin.com/in/binhoracle
👨 Twitter: https://twitter.com/binhguru
👨 Podcast: https://www.podbean.com/pu/pbblog-eskre-5f82d6
👨 Địa chỉ: Tòa nhà Sun Square - 21 Lê Đức Thọ - Phường Mỹ Đình 1 - Quận Nam Từ Liêm - TP.Hà Nội

=============================
oracle tutorial, học oracle database, Tự học Oracle, Tài liệu Oracle 12c tiếng Việt, Hướng dẫn sử dụng Oracle Database, Oracle SQL cơ bản, Oracle SQL là gì, Khóa học Oracle Hà Nội, Học chứng chỉ Oracle ở đầu, Khóa học Oracle online,sql tutorial, khóa học pl/sql tutorial, học dba, học dba ở việt nam, khóa học dba, khóa học dba sql, tài liệu học dba oracle, Khóa học Oracle online, học oracle sql, học oracle ở đâu tphcm, học oracle bắt đầu từ đâu, học oracle ở hà nội, oracle database tutorial, oracle database 12c, oracle database là gì, oracle database 11g, oracle download, oracle database 19c, oracle dba tutorial, oracle tunning, sql tunning , oracle 12c, oracle multitenant, Container Databases (CDB), Pluggable Databases (PDB), oracle cloud, oracle security, oracle fga, audit_trail,oracle RAC, ASM, oracle dataguard, oracle goldengate, mview, oracle exadata, oracle oca, oracle ocp, oracle ocm , oracle weblogic, postgresql tutorial, mysql tutorial, mariadb tutorial, ms sql server tutorial, nosql, mongodb tutorial, oci, cloud, middleware tutorial, hoc solaris tutorial, hoc linux tutorial, hoc aix tutorial, unix tutorial, securecrt, xshell, mobaxterm, putty

ĐỌC NHIỀU

Trần Văn Bình - Oracle Database Master