SQLite - जहां क्लॉज

SQLite WHERE एक तालिका या कई तालिकाओं से डेटा प्राप्त करते समय एक स्थिति निर्दिष्ट करने के लिए क्लॉज का उपयोग किया जाता है।

यदि दी गई स्थिति संतुष्ट है, तो इसका मतलब सही है, तो यह तालिका से विशिष्ट मूल्य लौटाता है। आपको रिकॉर्ड्स को फ़िल्टर करने और केवल आवश्यक रिकॉर्ड लाने के लिए WHERE क्लॉज़ का उपयोग करना होगा।

WHERE क्लॉज का उपयोग न केवल SELECT स्टेटमेंट में किया जाता है, बल्कि इसका उपयोग UPDATE, DELETE स्टेटमेंट आदि में भी किया जाता है, जो बाद के अध्यायों में शामिल किया जाएगा।

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

इसके बाद SQLite SELECT स्टेटमेंट का बेसिक सिंटैक्स है, जिसमें क्लॉज है।

SELECT column1, column2, columnN 
FROM table_name
WHERE [condition]

उदाहरण

आप इस तरह के>, <, =, LIKE, NOT इत्यादि जैसे कंपेरिजन या लॉजिकल ऑपरेटर्स का उपयोग करके एक शर्त निर्दिष्ट कर सकते हैं । निम्नलिखित रिकॉर्ड के साथ कंपनी की तालिका पर विचार करें -

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
1           Paul        32          California  20000.0
2           Allen       25          Texas       15000.0
3           Teddy       23          Norway      20000.0
4           Mark        25          Rich-Mond   65000.0
5           David       27          Texas       85000.0
6           Kim         22          South-Hall  45000.0
7           James       24          Houston     10000.0

निम्नलिखित एक सरल उदाहरण है जिसमें SQLite लॉजिकल ऑपरेटर्स का उपयोग दिखाया गया है। SELECT स्टेटमेंट के बाद उन सभी रिकॉर्ड्स को सूचीबद्ध करता है, जहां AGE 25 से अधिक या उसके बराबर हैAND वेतन 65000.00 से अधिक या इसके बराबर है।

sqlite> SELECT * FROM COMPANY WHERE AGE >= 25 AND SALARY >= 65000;

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
4           Mark        25          Rich-Mond   65000.0
5           David       27          Texas       85000.0

SELECT स्टेटमेंट के बाद उन सभी रिकॉर्ड्स को सूचीबद्ध करता है, जहां AGE 25 से अधिक या उसके बराबर है OR वेतन 65000.00 से अधिक या इसके बराबर है।

sqlite> SELECT * FROM COMPANY WHERE AGE >= 25 OR SALARY >= 65000;

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
1           Paul        32          California  20000.0
2           Allen       25          Texas       15000.0
4           Mark        25          Rich-Mond   65000.0
5           David       27          Texas       85000.0

SELECT स्टेटमेंट के बाद उन सभी रिकॉर्ड्स को सूचीबद्ध करता है, जहां AGE NULL नहीं है, जिसका अर्थ है सभी रिकॉर्ड क्योंकि किसी भी रिकॉर्ड में AGE NULL के बराबर नहीं है।

sqlite>  SELECT * FROM COMPANY WHERE AGE IS NOT NULL;

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
1           Paul        32          California  20000.0
2           Allen       25          Texas       15000.0
3           Teddy       23          Norway      20000.0
4           Mark        25          Rich-Mond   65000.0
5           David       27          Texas       85000.0
6           Kim         22          South-Hall  45000.0
7           James       24          Houston     10000.0

SELECT स्टेटमेंट के बाद उन सभी रिकॉर्ड्स को सूचीबद्ध करता है, जहाँ NAME 'Ki' से शुरू होता है, इससे कोई फर्क नहीं पड़ता कि 'Ki' के बाद क्या आता है।

sqlite> SELECT * FROM COMPANY WHERE NAME LIKE 'Ki%';

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
6           Kim         22          South-Hall  45000.0

SELECT स्टेटमेंट के बाद उन सभी रिकॉर्ड्स को सूचीबद्ध करता है, जहाँ NAME 'Ki' से शुरू होता है, इससे कोई फर्क नहीं पड़ता कि 'Ki' के बाद क्या आता है।

sqlite> SELECT * FROM COMPANY WHERE NAME GLOB 'Ki*';

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
6           Kim         22          South-Hall  45000.0

SELECT स्टेटमेंट के बाद उन सभी रिकॉर्ड्स को सूचीबद्ध करता है, जहां AGE वैल्यू या तो 25 या 27 है।

sqlite> SELECT * FROM COMPANY WHERE AGE IN ( 25, 27 );

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
2           Allen       25          Texas       15000.0
4           Mark        25          Rich-Mond   65000.0
5           David       27          Texas       85000.0

SELECT स्टेटमेंट के बाद उन सभी रिकॉर्ड्स को सूचीबद्ध करता है जहाँ AGE मान न तो 25 है और न ही 27।

sqlite> SELECT * FROM COMPANY WHERE AGE NOT IN ( 25, 27 );

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
1           Paul        32          California  20000.0
3           Teddy       23          Norway      20000.0
6           Kim         22          South-Hall  45000.0
7           James       24          Houston     10000.0

SELECT स्टेटमेंट के बाद उन सभी रिकॉर्ड्स को सूचीबद्ध करता है जहां AGE का मूल्य BETWEEN 25 और 27 में है।

sqlite> SELECT * FROM COMPANY WHERE AGE BETWEEN 25 AND 27;

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
2           Allen       25          Texas       15000.0
4           Mark        25          Rich-Mond   65000.0
5           David       27          Texas       85000.0

SELECT स्टेटमेंट के बाद SQL सब-क्वेरी का उपयोग होता है, जहाँ सब-क्वेरी AGE फ़ील्ड के साथ SALARY> 65000 के साथ सभी रिकॉर्ड पाता है और बाद में WHIS क्लॉज का उपयोग EXISTS ऑपरेटर के साथ उन सभी रिकॉर्डों को सूचीबद्ध करने के लिए किया जा रहा है, जहाँ बाहरी क्वेरी से AGE मौजूद है उप-क्वेरी द्वारा लौटाए गए परिणाम में -

sqlite> SELECT AGE FROM COMPANY 
   WHERE EXISTS (SELECT AGE FROM COMPANY WHERE SALARY > 65000);

AGE
----------
32
25
23
25
27
22
24

सेलेक्ट स्टेटमेंट के बाद SQL सब-क्वेरी का उपयोग करता है जहाँ सब-क्वेरी AGE फ़ील्ड के साथ SALARY> 65000 के साथ सभी रिकॉर्ड पाता है और बाद में WHERE क्लॉज़ का उपयोग> ऑपरेटर के साथ उन सभी रिकॉर्डों को सूचीबद्ध करने के लिए किया जाता है जहाँ बाहरी क्वेरी से AGE अधिक होता है। परिणाम में उम्र की तुलना में उप-क्वेरी द्वारा लौटाया गया।

sqlite> SELECT * FROM COMPANY 
   WHERE AGE > (SELECT AGE FROM COMPANY WHERE SALARY > 65000);

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
1           Paul        32          California  20000.0