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!