MySQLi - जहां क्लॉज है

हमने एसक्यूएल देखा है SELECTMySQLi तालिका से डेटा लाने के लिए कमांड। हम नामक एक सशर्त खंड का उपयोग कर सकते हैंWHEREपरिणामों को फ़िल्टर करने के लिए खंड। जहां क्लॉज का उपयोग करते हुए, हम एक टेबल से आवश्यक रिकॉर्ड का चयन करने के लिए एक चयन मानदंड निर्दिष्ट कर सकते हैं।

वाक्य - विन्यास

यहाँ MySQLi table से डेटा लाने के लिए WHECT क्लॉज़ के साथ SELECT कमांड का जेनेरिक SQL सिंटैक्स है -

SELECT field1, field2,...fieldN table_name1, table_name2...
[WHERE condition1 [AND [OR]] condition2.....
  • आप WHERE क्लॉज़ का उपयोग करके विभिन्न स्थितियों को शामिल करने के लिए अल्पविराम द्वारा अलग की गई एक या एक से अधिक तालिकाओं का उपयोग कर सकते हैं, लेकिन WHERE क्लॉज़ SELECT कमांड का एक वैकल्पिक हिस्सा है।

  • आप WHERE क्लॉज का उपयोग करके किसी भी शर्त को निर्दिष्ट कर सकते हैं।

  • आप एक से अधिक शर्तों का उपयोग करके निर्दिष्ट कर सकते हैं AND या OR ऑपरेटरों।

  • एक शर्त को निर्दिष्ट करने के लिए DELETE या UPDATE SQL कमांड के साथ भी इस्तेमाल किया जा सकता है।

WHEREखण्ड किसी भी प्रोग्रामिंग भाषा में एक शर्त की तरह काम करता है। इस खंड का उपयोग MySQLi तालिका में उपलब्ध फ़ील्ड मान के साथ दिए गए मूल्य की तुलना करने के लिए किया जाता है। यदि बाहर से दिया गया मूल्य MySQLi तालिका में उपलब्ध फ़ील्ड मान के बराबर है, तो यह उस पंक्ति को लौटाता है।

यहां ऑपरेटरों की सूची दी गई है, जिनका उपयोग किया जा सकता है WHERE खंड।

फ़ील्ड A मानें 10 और फ़ील्ड B 20 रखता है, तो -

ऑपरेटर विवरण उदाहरण
= जाँच करता है कि दो ऑपरेंड के मान समान हैं या नहीं, यदि हाँ तो स्थिति सच हो जाती है। (ए = बी) सच नहीं है।
! = जाँच करता है कि दो ऑपरेंड के मान समान हैं या नहीं, यदि मान बराबर नहीं हैं तो स्थिति सत्य हो जाती है। (ए! = बी) सच है।
> जाँच करता है कि क्या बाएं संकार्य का मान दाहिने संचालक के मान से अधिक है, यदि हाँ, तो स्थिति सत्य हो जाती है। (ए> बी) सच नहीं है।
< यह जाँचता है कि क्या बाएं संकार्य का मान दाहिने संचालक के मान से कम है, यदि हाँ तो स्थिति सही है। (ए <बी) सच है।
> = जाँच करता है कि क्या बाएं ऑपरेंड का मूल्य सही ऑपरेंड के मूल्य से अधिक या बराबर है, यदि हाँ तो स्थिति सच हो जाती है। (ए> = बी) सच नहीं है।
<= जाँच करता है कि क्या बाएं ऑपरेंड का मूल्य सही ऑपरेंड के मूल्य से कम या बराबर है, यदि हाँ तो स्थिति सच हो जाती है। (ए <= बी) सच है।

जब आप किसी तालिका से चयनित पंक्तियों को प्राप्त करना चाहते हैं, तो खासतौर पर जब आप उपयोग करते हैं, तो यह खंड बहुत उपयोगी है MySQLi Join। जोड़ों की चर्चा दूसरे अध्याय में की जाती है।

रिकॉर्ड का उपयोग करके खोज करना एक आम बात है Primary Key तेजी से खोज करने के लिए।

यदि दी गई स्थिति तालिका में किसी रिकॉर्ड से मेल नहीं खाती है, तो क्वेरी किसी भी पंक्ति में वापस नहीं आएगी।

कमांड प्रॉम्प्ट से डेटा ला रहा है

यह MySQLi table tutorials_inf से चयनित डेटा लाने के लिए WHERE क्लॉज़ के साथ SQL SELECT कमांड का उपयोग करेगा।

उदाहरण

निम्नलिखित उदाहरण से सभी रिकॉर्ड वापस आ जाएंगे tutorials_inf तालिका जिसके लिए नाम है sai -

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

mysql> use TUTORIALS;
Database changed

mysql>SELECT * from tutorials_inf where name = 'sai';
+----+------+
| id | name |
+----+------+
|  1 | SAI  |
+----+------+
1 row in set (0.00 sec)

mysql>

जब तक कोई प्रदर्शन नहीं करता LIKEएक स्ट्रिंग पर तुलना, मामला संवेदनशील नहीं है। आप अपने खोज मामले का उपयोग करके संवेदनशील बना सकते हैंBINARY कीवर्ड इस प्रकार है -

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

mysql> use TUTORIALS;
Database changed

mysql> SELECT * from tutorials_inf \WHERE BINARY name = 'sai';
Empty set (0.02 sec)

mysql>

PHP स्क्रिप्ट का उपयोग करके डेटा लाना:

आप PHP फ़ंक्शन में WHAL CLAUSE के साथ उसी SQL SELECT कमांड का उपयोग कर सकते हैं mysqli_query()

उदाहरण

निम्नलिखित उदाहरण से सभी रिकॉर्ड वापस आ जाएंगे tutorials_inf तालिका जिसके लिए नाम है sai -

<?php
   $dbhost = 'localhost:3306';
   $dbuser = 'root';
   $dbpass = '';
   $dbname = 'TUTORIALS';
   $conn = mysqli_connect($dbhost, $dbuser, $dbpass,$dbname);
   
   if(! $conn ) {
      die('Could not connect: ' . mysqli_error());
   }
   echo 'Connected successfully<br>';
   $sql = 'SELECT * from tutorials_inf where name="sai"';
   $result = mysqli_query($conn, $sql);

   if (mysqli_num_rows($result) > 0) {
      while($row = mysqli_fetch_assoc($result)) {
         echo "Name: " . $row["name"]. "<br>";
      }
   } else {
      echo "0 results";
   }
   mysqli_close($conn);
?>

नमूना उत्पादन इस तरह होना चाहिए -

Connected successfully
Name: SAI