Left Join trong MySQL
Left join trong MySQL cũng giống như Inner Join, có một điểu khác là nó sẽ lấy kết quả ở bên trái trong trường hợp bên phải không có dữ liệu phù hợp.
Giả sử cần join 2 bảng A và B thì:
- A join B: Trả về kết quả thỏa ở điều kiện ON.
- A Left join B: Trả về kết quả thỏa ở điều kiện ON và những record không thỏa ở bảng A.
Mình sẽ lấy một dữ liệu đơn giản như sau để thực hành trong bài, bạn sẽ dễ hiểu hơn lệnh LEFT JOIN này.
1. Dữ liệu thực hành Left Join MySQL
Cho bảng Students có dữ liệu như sau:
Bài viết này được đăng tại [free tuts .net]
Bảng Class như sau:
Như bạn thấy, bảng students có một khóa ngoại class_id
trỏ đến bảng class.
Có một sinh viên tên là Duong Van Hoi không thuộc một lớp nào cả (vì class_id = 0). Bây giờ ta sẽ thực hiện một vài phép LEFT JOIN cơ bản.
2. Cách sử dụng Join Left trong MySQL
Bài toán 1: Lấy tất cả thông tin sinh viên và lớp mà sinh viên đó đang học.
SELECT * FROM students JOIN class ON students.class_id = class.class_id
Kết quả:
Trả về 2 kết quả là đúng, tai vì sinh viên thứ 2 có khóa ngoại class_id = 0 nên không thuộc một lớp nào cả.
Bài toán 2: Lấy tất cả thông tin sinh viên và lớp đang học, nếu không có học lớp nào cũng phải trả kết quả.
SELECT * FROM students LEFT JOIN class ON students.class_id = class.class_id
Kết quả:
Sinh viên Dương Van Hoi mặc dù không thuộc lớp nào nhưng vẫn được trả về.
Qua hai ví dụ trên thì chắc hẳn bạn đã hiểu được ý nghĩa của lệnh Left Join rồi phải không nào? Bài này mình sẽ dừng ở đây, bài tiếp theo ta sẽ nói về lệnh Right Join.