MySQLi - NULL Values ​​को संभालना

हमने एसक्यूएल देखा है SELECT साथ में कमान WHERE MySQLi table से डेटा प्राप्त करने के लिए क्लॉज़, लेकिन जब हम एक शर्त देने की कोशिश करते हैं, जिसमें फ़ील्ड या कॉलम मान की तुलना की जाती है NULL, यह ठीक से काम नहीं करता है।

ऐसी स्थिति से निपटने के लिए MySQLi तीन ऑपरेटरों को प्रदान करता है

  • IS NULL - अगर कॉलम वैल्यू NULL है तो ऑपरेटर सही रिटर्न देता है।

  • IS NOT NULL - यदि कॉलम वैल्यू NULL नहीं है तो ऑपरेटर सही रिटर्न करता है।

  • <=> - ऑपरेटर मूल्यों की तुलना करता है, जो (= ऑपरेटर के विपरीत) दो पूर्ण मूल्यों के लिए भी सही है।

NULL से जुड़ी शर्तें विशेष हैं। आप कॉलम में NULL मान देखने के लिए = NULL या! = NULL का उपयोग नहीं कर सकते। इस तरह की तुलना हमेशा विफल होती है क्योंकि यह बताना असंभव है कि वे सच हैं या नहीं। यहां तक ​​कि NULL = NULL विफल।

ऐसे कॉलम देखने के लिए जो NULL हैं या नहीं हैं, IS NULL या IS NOT NULL का उपयोग करें।

कमांड प्रॉम्प्ट पर NULL मान का उपयोग करना

मान लीजिए एक मेज tutorials_bks TUTORIALS डेटाबेस में और इसमें दो कॉलम होते हैं id तथा name, जहां एक NULL नाम इंगित करता है कि मान अज्ञात है -

उदाहरण

निम्नलिखित उदाहरण देखें -

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> INSERT INTO tutorials_bks (book) values('');
Query OK, 1 row affected (0.08 sec)

mysql> INSERT INTO tutorials_bks (book) values('');
Query OK, 1 row affected (0.08 sec)

mysql> INSERT INTO tutorials_bks (book) values('');
Query OK, 1 row affected (0.08 sec)

mysql> INSERT INTO tutorials_bks (book) values('NULL');
Query OK, 1 row affected (0.08 sec)

mysql> INSERT INTO tutorials_bks (book) values('NULL');
Query OK, 1 row affected (0.08 sec)

mysql> INSERT INTO tutorials_bks (book) values('NULL');
Query OK, 1 row affected (0.08 sec)

+----+---------+
| id | book    |
+----+---------+
|  1 | java    |
|  2 | java    |
|  3 | html    |
|  4 | c++     |
|  5 | Android |
|  6 |         |
|  7 |         |
|  8 |         |
|  9 | NULL    |
| 10 | NULL    |
| 11 | NULL    |
+----+---------+
11 rows in set (0.00 sec)

mysql>

रिकॉर्ड्स खोजने के लिए जहां नाम कॉलम है या NULL नहीं है, प्रश्नों को इस तरह लिखा जाना चाहिए -

mysql> SELECT * FROM tutorials_bks WHERE book = "null";
+----+------+
| id | book |
+----+------+
|  9 | NULL |
| 10 | NULL |
| 11 | NULL |
+----+------+
3 rows in set (0.00 sec)

mysql> SELECT * FROM tutorials_bks WHERE book ! = "null";
+----+---------+
| id | book    |
+----+---------+
|  1 | java    |
|  2 | java    |
|  3 | html    |
|  4 | c++     |
|  5 | Android |
|  6 |         |
|  7 |         |
|  8 |         |
+----+---------+
8 rows in set (0.00 sec)

mysql> SELECT * FROM tutorials_bks WHERE book = "";
+----+------+
| id | book |
+----+------+
|  6 |      |
|  7 |      |
|  8 |      |
+----+------+
3 rows in set (0.01 sec)

PHP स्क्रिप्ट में NULL मान को संभालना

यदि आप ... NULL मान के आधार पर क्वेरी तैयार करने के लिए शर्त का उपयोग कर सकते हैं ।

उदाहरण

निम्नलिखित उदाहरण बाहर से tutorial_count लेता है और फिर तालिका में उपलब्ध मूल्य से इसकी तुलना करता है।

<?php
   $dbhost = 'localhost:3036'; $dbuser = 'root';
   $dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
      die('Could not connect: ' . mysql_error());
   }
   if( isset($tutorial_count )) { $sql = 'SELECT tutorial_author, tutorial_count FROM  tcount_tbl
         WHERE tutorial_count = $tutorial_count'; } else { $sql = 'SELECT tutorial_author, tutorial_count
         FROM  tcount_tbl WHERE tutorial_count IS $tutorial_count'; } mysql_select_db('TUTORIALS'); $retval = mysql_query( $sql, $conn );
   
   if(! $retval ) { die('Could not get data: ' . mysql_error()); } while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) { echo "Author:{$row['tutorial_author']}  <br> ".
         "Count: {$row['tutorial_count']} <br> ". "--------------------------------<br>"; } echo "Fetched data successfully\n"; mysql_close($conn);
?>