Tóm Tắt
1/ Phép JOIN là gì?
Phép JOIN trong SQL dùng để truy vấn lấy tài 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ó công dụng tương tự như, có điều nó sẽ lọc theo một điều kiện kèm theo đơn cử 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.
Bạn đang đọc: Inner JOIN trong SQL – https://final-blade.com
Cú pháp Inner Join như sau :
1234 |
SELECTcolumns FROMtable1 INNERJOINtable2 ONtable1.column=table2.column; |
Trong đó :
-
table1
vàtable2
là hai bảng cần thực hiện join - t
able1.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
123456 |
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
1234 |
ID|NAME —-+———————————– 1|CôngNghệThôngTin 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 list toàn bộ sinh viên và thông tin về khoa mà sinh viên đang học .
123 |
SELECTSV.ID,SV.NAMEASSV_NAME,K.NAMEASK_NAME FROMSINHVIENASSVJOINKHOAASK ONKHOA_ID=K.ID |
Kết quả sẽ trả về list như sau :
123456 |
ID|SV_NAME|K_NAME —-+————=–+——+———— 1|Cường|CôngNghệThôngTin 2|Kính|Toán 3|Quyền|CôngNghệThôngTin 4|Tình|Toán |
Rõ ràng tác dụng 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ổ trợ thêm điều kiện kèm theo nào đó thì hãy bổ trợ 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 :
1234 |
SELECTSV.ID,SV.NAMEASSV_NAME,K.NAMEASK_NAME FROMSINHVIENASSVJOINKHOAASK ONKHOA_ID=K.ID WHERESV.NAME= “Cường” Xem thêm: UPDATE trong SQL Server | Comdy |
Quá đơn thuần phải không các bạn .
Mặc dù bạn trọn vẹ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 quy trình thực thi nối hai bảng thì nó sẽ chạy luôn điều kiện kèm theo lọc ở ON, chỉ có cặp records nào tương thích mới được lấy nên sẽ tối ưu hơn tích đề các .
Source: https://final-blade.com
Category: Kiến thức Internet