Chủ Nhật, 30 tháng 7, 2023

Inner JOIN trong SQL

Ở bài trước chúng ta đã học hiểu cách truy vấn nhiều bảng trong SQL bằng cách thực hiện phép tích đề các, vậy thì trong bài này mình sẽ nói đến phép INNER JOIN cũng dùng để truy vấn nhiều bảng nhưng tốc độ và tính hiệu quả của nó tốt hơn rất nhiều so với việc thực hiện một phép tích đề các.

Mục lục

  • 1/ Phép JOIN là gì?
  • 2/ Ví dụ Inner JOIN

1/ Phép JOIN là gì?

Phép JOIN trong SQL dùng để truy vấn lấy dữ liệu từ nhiều bảng dựa vào một mối liên hệ nào đó, thường sẽ dựa vào mối liên hệ khóa ngoại. Nếu phép tích trả về tổng số lượng records bằng tích records của hai bảng thì phép JOIN cũng có tác dụng tương tự, có điều nó sẽ lọc theo một điều kiện cụ thể nên tổng số records sẽ ít hơn.

Có tổng cộng 4 loại JOIN chính trong SQL đó là: Inner Join, Left Join, Right Join, Self Join, và trong bài này chúng ta sẽ tìm hiểu Inner Join trước.

Cú pháp Inner Join như sau:

Bài viết này được đăng tại tranvanbinh.vn, vietdba.vn

1
2
3
4
SELECT columns 
FROM table1  
INNER JOIN table2 
ON table1.column = table2.column;

Trong đó:

  • table1 và table2 là hai bảng cần thực hiện join
  • table1.column = table2.column chính là điều kiện để lọc

Kết quả sẽ trả về những records thỏa điền kiện ở ON (xem hình).


2/ Ví dụ Inner JOIN

Giả sử mình có bảng SINHVIEN và KHOA như sau:

SINHVIEN
1
2
3
4
5
6
ID  |    NAME    |    AGE  |   KHOA_ID
----+------------+---------+------------
1   |    Cường   |    28   |   1
2   |    Kính    |    26   |   2
3   |    Quyền   |    20   |   1
4   |    Tình    |    25   |   2

KHOA
1
2
3
4
ID  |    NAME
----+-----------------------------------
1   |    Công Nghệ Thông Tin
2   |    Toán

Nhìn vào đây thì ta sẽ thấy mối liên hệ khóa ngoại ở bảng SINHVIEN đó là KHOA_ID, nó sẽ trỏ đến khóa chính của bảng KHOA. Bây giờ mình muốn lấy danh sách tất cả sinh viên và thông tin về khoa mà sinh viên đang học.

1
2
3
SELECT SV.ID, SV.NAME AS SV_NAME, K.NAME AS K_NAME
FROM SINHVIEN AS SV JOIN KHOA AS K
ON KHOA_ID = K.ID

Kết quả sẽ trả về danh sách như sau:

1
2
3
4
5
6
ID  |    SV_NAME    |    K_NAME
----+------------=--+------+------------
1   |    Cường      |    Công Nghệ Thông Tin
2   |    Kính       |    Toán
3   |    Quyền      |    Công Nghệ Thông Tin
4   |    Tình       |    Toán

Rõ ràng kết quả sẽ trả về ít hơn và tối ưu hơn so với phép tích đề các.

Nếu bạn muốn bổ sung thêm điều kiện nào đó thì hãy bổ sung nó ở WHERE. Ví dụ mình muốn lấy thông tin sinh viên Cường và khoa mà Cường đang học thì viết câu SQL như sau:

1
2
3
4
SELECT SV.ID, SV.NAME AS SV_NAME, K.NAME AS K_NAME
FROM SINHVIEN AS SV JOIN KHOA AS K
    ON KHOA_ID = K.ID
WHERE SV.NAME = "Cường"

Quá đơn giản phải không các bạn.

Mặc dù bạn hoàn toàn có thể sử dụng phép tích trong trường hợp này, tuy nhiên vẫn nên sử dụng Inner Join vì trong quá trình thực hiện nối hai bảng thì nó sẽ chạy luôn điều kiện lọc ở ON, chỉ có cặp records nào phù hợp mới được lấy nên sẽ tối ưu hơn tích đề các.

=============================
Nếu bạn muốn tiết kiệm 3-5 NĂM trên con đường trở thành DBA chuyên nghiệp thì hãy đăng ký ngay KHOÁ HỌC ORACLE DATABASE A-Z ENTERPRISE, được Coaching trực tiếp từ tôi với toàn bộ kinh nghiệm, thủ tục, quy trình, bí kíp thực chiến mà bạn sẽ KHÔNG THỂ tìm kiếm trên Internet/Google giúp bạn dễ dàng quản trị mọi hệ thống Core tại Việt Nam và trên thế giới, đỗ OCP.
- 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
=============================
2 khóa học online qua video giúp bạn nhanh chóng có những kiến thức nền tảng về Linux, Oracle, học mọi nơi, chỉ cần có Internet/4G:
- Oracle cơ bản: https://bit.ly/admin1_1200
- Linux: https://bit.ly/linux_1200
=============================
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