Rumah >pangkalan data >tutorial mysql >Bagaimanakah MySQL Mengendalikan Perbandingan Ketaksamaan dengan Nilai NULL?
Apabila berurusan dengan lajur jadual yang mungkin mengandungi nilai NULL, adalah penting untuk memahami cara MySQL mengendalikan perbandingan yang melibatkan NULL.
Masalah berlaku apabila menggunakan perbandingan ketaksamaan (CODE!='C'), tetapi nilai NULL tidak dipertimbangkan. Dalam kes ini, MySQL secara senyap akan mengecualikan rekod yang mengandungi nilai NULL daripada set hasil, menjadikannya kelihatan bahawa rekod ini tidak wujud.
Untuk memasukkan rekod yang mengandungi nilai NULL dalam set hasil, perbandingan mesti dilanjutkan secara eksplisit untuk mengambil kira NULL. Cara yang betul ialah menggunakan sintaks berikut:
<code class="language-sql">SELECT * FROM TABLE WHERE CODE IS NULL OR CODE!='C'</code>
Dengan menggunakan operator IS NULL, MySQL secara eksplisit menyemak rekod yang lajur KODnya adalah NULL, memastikan bahawa ia dimasukkan dalam set keputusan bersama-sama dengan rekod yang KODnya tidak sama dengan 'C'.
Tingkah laku MySQL dalam situasi ini boleh dikaitkan dengan cara ia melayan NULL sebagai nilai yang tidak diketahui atau tidak ditentukan. Perbandingan ketaksamaan, seperti !=, kembali benar hanya jika terdapat perbezaan yang jelas antara operan. Oleh kerana NULL ialah nilai yang tidak diketahui, ia tidak dianggap berbeza daripada mana-mana nilai lain (termasuk 'C').
Oleh itu, apabila menggunakan perbandingan ketidaksamaan, pastikan anda mengambil kira nilai NULL secara eksplisit untuk memastikan hasil yang tepat. Pengendali IS NULL menyediakan cara yang boleh dipercayai untuk mengendalikan situasi ini dan memastikan semua data yang berkaitan dikembalikan.
Atas ialah kandungan terperinci Bagaimanakah MySQL Mengendalikan Perbandingan Ketaksamaan dengan Nilai NULL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!