Menyiasat Baris dengan Nilai Lajur Tidak Berbeza
Dalam SQL, tugas biasa adalah untuk mendapatkan semula baris dengan nilai lajur tertentu adalah tidak berbeza. Ini boleh berguna dalam mengenal pasti data pendua atau mengesan anomali.
Senario Contoh
Pertimbangkan jadual bernama Pelanggan yang mengandungi data berikut:
CustomerName | EmailAddress |
---|---|
Aaron | [email protected] |
Christy | [email protected] |
Jason | [email protected] |
Eric | [email protected] |
John | [email protected] |
Untuk mendapatkan semula semua baris di mana lajur EmailAddress tidak berbeza, kami boleh menggunakan yang berikut pertanyaan:
SELECT EmailAddress, CustomerName FROM Customers WHERE EmailAddress IN (SELECT EmailAddress FROM Customers GROUP BY EmailAddress HAVING COUNT(*) > 1)
Penjelasan
Klausa IN menapis untuk nilai EmailAddress yang terdapat dalam subkueri. Subkueri mengumpulkan semua nilai EmailAddress dan mengira kejadian setiap nilai. Klausa HAVING kemudiannya memilih kumpulan yang mempunyai lebih daripada satu kejadian (iaitu, nilai tidak berbeza).
Dengan menggunakan pendekatan ini, kami mengenal pasti dan mengembalikan baris dengan cekap yang lajur EmailAddress tidak berbeza. Kaedah ini jauh lebih pantas daripada menggunakan operator EXISTS dalam kebanyakan kes.
Atas ialah kandungan terperinci Bagaimana untuk Mencari dan Mendapatkan Baris dengan Nilai Lajur Bukan Unik dalam SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!