Rumah >pangkalan data >tutorial mysql >Perbandingan SQL NULL: Mengapa Gunakan 'x IS NULL' Daripada 'x = NULL'?
SQL: Memahami perbezaan antara 'x is null' dan 'x = null'
SQL menyediakan dua cara berbeza untuk menguji lajur untuk nilai NULL: 'x is null' dan 'x = null'. Walaupun kedua-dua ungkapan ini kelihatan serupa, tingkah laku mereka berbeza dengan ketara.
'x = null' vs 'x is null': perbezaan utama
Ungkapan 'x = null' ialah operasi perbandingan yang menyemak sama ada nilai 'x' adalah sama dengan nilai NULL literal. Walau bagaimanapun, dalam SQL, sebarang perbandingan yang melibatkan nilai NULL, termasuk 'x = null', akan sentiasa mengembalikan 'null'. Ini kerana nilai NULL dalam SQL mewakili nilai yang tidak diketahui, jadi ia tidak dapat ditentukan sama ada nilai tersebut sama dengan nilai lain.
Sebaliknya, 'x is null' ialah ungkapan yang secara khusus menguji kehadiran nilai NULL. Mengembalikan 'benar' jika 'x' adalah NULL; Ini membolehkan ujian tepat bagi nilai NULL tanpa kekaburan yang dikaitkan dengan 'x = null'.
Mengapa 'x = null' tidak berfungsi
Seperti yang dinyatakan sebelum ini, 'x = null' akan sentiasa mengembalikan 'null' dalam SQL. Ini bermakna apabila digunakan dalam klausa WHERE, ia tidak akan menghasilkan sebarang baris yang sepadan kerana 'null' dianggap palsu dalam kes ini.
Contoh
Pertimbangkan borang berikut:
X | Y |
---|---|
1 | null |
null | 1 |
Jika anda melaksanakan pertanyaan 'SELECT * FROM t WHERE x = null', anda tidak akan mendapat sebarang baris walaupun terdapat baris dengan 'x' ialah 'null'. Ini kerana 'x = null' sentiasa menilai kepada 'null', yang palsu dalam klausa WHERE.
Gunakan 'x is null' untuk ujian nilai NULL yang tepat
Untuk menguji nilai NULL dengan betul, gunakan 'x is null' dan bukannya 'x = null'. Berikut ialah contoh yang akan mengembalikan baris yang diperlukan:
<code class="language-sql">SELECT * FROM t WHERE x is null</code>
Pertanyaan ini akan kembali:
X | Y |
---|---|
null | 1 |
Kesimpulan
Memahami perbezaan antara 'x is null' dan 'x = null' adalah penting untuk pengaturcaraan SQL yang berkesan. 'x = null' membandingkan 'x' kepada nilai NULL literal dan sentiasa mengembalikan 'null', manakala 'x is null' secara khusus menguji kehadiran nilai NULL. Apabila menguji nilai NULL, sentiasa gunakan 'x is null' untuk hasil yang tepat.
Atas ialah kandungan terperinci Perbandingan SQL NULL: Mengapa Gunakan 'x IS NULL' Daripada 'x = NULL'?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!