MySQL NULL Values ​​को संभालना

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

ऐसी स्थिति से निपटने के लिए, MySQL तीन ऑपरेटर प्रदान करता है -

  • IS NULL - यह ऑपरेटर सही है, यदि स्तंभ का मान NULL है।

  • IS NOT NULL - यह ऑपरेटर सही है, यदि स्तंभ का मान NULL नहीं है।

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

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

उन स्तंभों को देखने के लिए जो NULL हैं या नहीं हैं, का उपयोग करें IS NULL या IS NOT NULL

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

मान लें कि एक तालिका है जिसे कहा जाता है tcount_tbl TUTORIALS डेटाबेस में और इसमें दो कॉलम होते हैं tutorial_author तथा tutorial_count, जहां NULL tutorial_count इंगित करता है कि मान अज्ञात है।

उदाहरण

निम्नलिखित उदाहरणों को आज़माएँ -

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

mysql> use TUTORIALS;
Database changed

mysql> create table tcount_tbl
   -> (
   -> tutorial_author varchar(40) NOT NULL,
   -> tutorial_count  INT
   -> );
Query OK, 0 rows affected (0.05 sec)

mysql> INSERT INTO tcount_tbl
   -> (tutorial_author, tutorial_count) values ('mahran', 20);

mysql> INSERT INTO tcount_tbl
   -> (tutorial_author, tutorial_count) values ('mahnaz', NULL);

mysql> INSERT INTO tcount_tbl
   -> (tutorial_author, tutorial_count) values ('Jen', NULL);

mysql> INSERT INTO tcount_tbl
   -> (tutorial_author, tutorial_count) values ('Gill', 20);

mysql> SELECT * from tcount_tbl;
+-----------------+----------------+
| tutorial_author | tutorial_count |
+-----------------+----------------+
|     mahran      |       20       |
|     mahnaz      |      NULL      |
|      Jen        |      NULL      |
|     Gill        |       20       |
+-----------------+----------------+
4 rows in set (0.00 sec)

mysql>

आप देख सकते हैं कि = और != निम्न के रूप में पूर्ण मानों के साथ काम न करें -

mysql> SELECT * FROM tcount_tbl WHERE tutorial_count = NULL;
Empty set (0.00 sec)

mysql> SELECT * FROM tcount_tbl WHERE tutorial_count != NULL;
Empty set (0.01 sec)

उन रिकॉर्ड्स को खोजने के लिए जहां tutorial_count कॉलम है या NULL नहीं है, प्रश्नों को निम्न प्रोग्राम में दिखाए गए अनुसार लिखा जाना चाहिए।

mysql> SELECT * FROM tcount_tbl 
   -> WHERE tutorial_count IS NULL;
+-----------------+----------------+
| tutorial_author | tutorial_count |
+-----------------+----------------+
|     mahnaz      |      NULL      |
|      Jen        |      NULL      |
+-----------------+----------------+
2 rows in set (0.00 sec)
mysql> SELECT * from tcount_tbl 
   -> WHERE tutorial_count IS NOT NULL;
+-----------------+----------------+
| tutorial_author | tutorial_count |
+-----------------+----------------+
|     mahran      |       20       |
|     Gill        |       20       |
+-----------------+----------------+
2 rows in set (0.00 sec)

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

आप उपयोग कर सकते हैं if...else 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);
?>