06/04/2021, 14:50

Left Join trong MySQL - MySQL căn bản

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ề ...

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:

students JPG

Bảng Class như sau:

class JPG

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ả:

join JPG

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ả:

join left ket qua JPG

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.

Bùi Văn Nam

27 chủ đề

7090 bài viết

Cùng chủ đề
0