Rumah >pangkalan data >tutorial mysql >Bagaimanakah LEFT JOIN dalam SQL Mengenalpasti Data yang Sedia Ada dalam Satu Jadual Tetapi Bukan Lain?

Bagaimanakah LEFT JOIN dalam SQL Mengenalpasti Data yang Sedia Ada dalam Satu Jadual Tetapi Bukan Lain?

Barbara Streisand
Barbara Streisandasal
2025-01-03 02:16:38558semak imbas

How Can a LEFT JOIN in SQL Identify Data Existing in One Table But Not Another?

Mencari Data Tidak Sedia Ada Menggunakan LEFT JOIN

Dalam SQL, keperluan mungkin timbul untuk membandingkan dua jadual dan mengenal pasti data yang wujud dalam satu tetapi bukan yang lain. Senario ini biasanya ditemui semasa menyemak rekod yang hilang.

Pertimbangkan jadual berikut:

JADUAL1

id name address
1 mm 123
2 nn 143

JADUAL2

name age
mm 6
oo 9

Objektifnya adalah untuk mencari nama yang tidak wujud dalam JADUAL1 dengan membandingkannya dengan JADUAL2. Dalam kes ini, baris kedua dalam TABLE1 dengan nama "nn" tidak wujud dalam TABLE2.

Percubaan awal menggunakan INNER JOIN:

SELECT w.*
FROM TABLE1 w
INNER JOIN TABLE2 v
ON w.name <> v.name

akan gagal untuk mendapatkan semula yang diingini keputusan kerana INNER JOIN hanya mengembalikan baris yang terdapat padanan dalam kedua-dua jadual.

Penyelesaian terletak pada menggunakan LEFT JOIN sebaliknya:

SELECT w.*
FROM TABLE1 w
LEFT JOIN TABLE2 v ON w.name = v.name
WHERE ISNULL(v.name);

LEFT JOIN melakukan gabungan luar, yang bermaksud ia akan mengembalikan semua baris dari jadual kiri (JADUAL1) tanpa mengira sama ada terdapat baris yang sepadan dalam jadual kanan (JADUAL2). Keadaan ISNULL(v.name) menyemak baris dalam JADUAL1 dengan medan nama yang sepadan dalam JADUAL2 adalah batal, menunjukkan bahawa nama itu tidak wujud dalam JADUAL2.

Outputnya ialah:

id name address
2 nn 143

Pertanyaan ini berjaya mendapatkan semula baris daripada JADUAL1 dengan nama yang tidak wujud "nn".

Atas ialah kandungan terperinci Bagaimanakah LEFT JOIN dalam SQL Mengenalpasti Data yang Sedia Ada dalam Satu Jadual Tetapi Bukan Lain?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn