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