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

एक तालिका से डेटा प्राप्त करते समय या एक से अधिक तालिकाओं के साथ जुड़ने के दौरान एक शर्त निर्दिष्ट करने के लिए PostgreSQL WHERE क्लॉज का उपयोग किया जाता है।

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

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

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

WHERE क्लॉज के साथ SELECT स्टेटमेंट का मूल सिंटैक्स इस प्रकार है -

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

आप तुलना या तार्किक ऑपरेटरों का उपयोग करके एक search_condition निर्दिष्ट कर सकते हैं । जैसे>, <, =, LIKE, NOT, आदि निम्नलिखित उदाहरण इस अवधारणा को स्पष्ट करेंगे।

उदाहरण

तालिका पर विचार करें कंपनी के रिकॉर्ड निम्नानुसार हैं -

testdb# select * from COMPANY;
 id | name  | age | address   | salary
----+-------+-----+-----------+--------
  1 | Paul  |  32 | California|  20000
  2 | Allen |  25 | Texas     |  15000
  3 | Teddy |  23 | Norway    |  20000
  4 | Mark  |  25 | Rich-Mond |  65000
  5 | David |  27 | Texas     |  85000
  6 | Kim   |  22 | South-Hall|  45000
  7 | James |  24 | Houston   |  10000
(7 rows)

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

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

ऊपर दिया गया PostgreSQL स्टेटमेंट निम्न परिणाम देगा -

id | name  | age |  address   | salary
----+-------+-----+------------+--------
  4 | Mark  |  25 | Rich-Mond  |  65000
  5 | David |  27 | Texas      |  85000
(2 rows)

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

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

ऊपर दिया गया PostgreSQL स्टेटमेंट निम्न परिणाम देगा -

id | name  | age | address     | salary
----+-------+-----+-------------+--------
  1 | Paul  |  32 | California  |  20000
  2 | Allen |  25 | Texas       |  15000
  4 | Mark  |  25 | Rich-Mond   |  65000
  5 | David |  27 | Texas       |  85000
(4 rows)

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

testdb=#  SELECT * FROM COMPANY WHERE AGE IS NOT NULL;

ऊपर दिया गया PostgreSQL स्टेटमेंट निम्न परिणाम देगा -

id | name  | age | address    | salary
 ----+-------+-----+------------+--------
   1 | Paul  |  32 | California |  20000
   2 | Allen |  25 | Texas      |  15000
   3 | Teddy |  23 | Norway     |  20000
   4 | Mark  |  25 | Rich-Mond  |  65000
   5 | David |  27 | Texas      |  85000
   6 | Kim   |  22 | South-Hall |  45000
   7 | James |  24 | Houston    |  10000
(7 rows)

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

testdb=# SELECT * FROM COMPANY WHERE NAME LIKE 'Pa%';

ऊपर दिया गया PostgreSQL स्टेटमेंट निम्न परिणाम देगा -

id | name | age |address    | salary
----+------+-----+-----------+--------
  1 | Paul |  32 | California|  20000

निम्नलिखित चयन कथन उन सभी रिकॉर्डों को सूचीबद्ध करता है जहां AGE मूल्य या तो 25 या 27 है -

testdb=# SELECT * FROM COMPANY WHERE AGE IN ( 25, 27 );

ऊपर दिया गया PostgreSQL स्टेटमेंट निम्न परिणाम देगा -

id | name  | age | address    | salary
----+-------+-----+------------+--------
  2 | Allen |  25 | Texas      |  15000
  4 | Mark  |  25 | Rich-Mond  |  65000
  5 | David |  27 | Texas      |  85000
(3 rows)

निम्नलिखित चयन कथन उन सभी रिकॉर्डों को सूचीबद्ध करता है, जहां AGE मूल्य न तो 25 है और न ही 27 -

testdb=# SELECT * FROM COMPANY WHERE AGE NOT IN ( 25, 27 );

ऊपर दिया गया PostgreSQL स्टेटमेंट निम्न परिणाम देगा -

id | name  | age | address    | salary
----+-------+-----+------------+--------
  1 | Paul  |  32 | California |  20000
  3 | Teddy |  23 | Norway     |  20000
  6 | Kim   |  22 | South-Hall |  45000
  7 | James |  24 | Houston    |  10000
(4 rows)

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

testdb=# SELECT * FROM COMPANY WHERE AGE BETWEEN 25 AND 27;

ऊपर दिया गया PostgreSQL स्टेटमेंट निम्न परिणाम देगा -

id | name  | age | address    | salary
----+-------+-----+------------+--------
  2 | Allen |  25 | Texas      |  15000
  4 | Mark  |  25 | Rich-Mond  |  65000
  5 | David |  27 | Texas      |  85000
(3 rows)

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

testdb=# SELECT AGE FROM COMPANY
        WHERE EXISTS (SELECT AGE FROM COMPANY WHERE SALARY > 65000);

ऊपर दिया गया PostgreSQL स्टेटमेंट निम्न परिणाम देगा -

age
-----
  32
  25
  23
  25
  27
  22
  24
(7 rows)

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

testdb=# SELECT * FROM COMPANY
        WHERE AGE > (SELECT AGE FROM COMPANY WHERE SALARY > 65000);

ऊपर दिया गया PostgreSQL स्टेटमेंट निम्न परिणाम देगा -

id | name | age | address    | salary
----+------+-----+------------+--------
  1 | Paul |  32 | California |  20000