PostgreSQL - हवलिंग क्लाज

HAVING क्लॉज हमें विशेष पंक्तियों को चुनने की अनुमति देता है जहां फ़ंक्शन का परिणाम कुछ स्थिति से मिलता है।

WHERE क्लॉज चयनित कॉलम पर स्थितियां रखता है, जबकि HAVING क्लॉज GROUP BY क्लॉज द्वारा बनाए गए समूहों पर स्थितियां रखता है।

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

निम्नलिखित का चयन एक प्रश्न में HAVING खंड की स्थिति है -

SELECT
FROM
WHERE
GROUP BY
HAVING
ORDER BY

HAVING क्लॉज को एक क्वेरी में GROUP BY क्लॉज का पालन करना चाहिए और यदि उपयोग किया जाता है तो ORDER BY क्लॉज से पहले भी होना चाहिए। निम्नलिखित चयन कथन का सिंटैक्स है, जिसमें HAVING खंड शामिल है -

SELECT column1, column2
FROM table1, table2
WHERE [ conditions ]
GROUP BY column1, column2
HAVING [ conditions ]
ORDER BY column1, column2

उदाहरण

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

# 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)

निम्नलिखित एक उदाहरण है, जो रिकॉर्ड प्रदर्शित करेगा जिसके लिए नाम की संख्या 2 से कम है -

testdb-# SELECT NAME FROM COMPANY GROUP BY name HAVING count(name) < 2;

यह निम्नलिखित परिणाम का उत्पादन करेगा -

name
 -------
  Teddy
  Paul
  Mark
  David
  Allen
  Kim
  James
(7 rows)

अब, निम्नलिखित INSERT कथनों का उपयोग करके कंपनी तालिका में तीन और रिकॉर्ड बनाते हैं -

INSERT INTO COMPANY VALUES (8, 'Paul', 24, 'Houston', 20000.00);
INSERT INTO COMPANY VALUES (9, 'James', 44, 'Norway', 5000.00);
INSERT INTO COMPANY VALUES (10, 'James', 45, 'Texas', 5000.00);

अब, हमारी तालिका में डुप्लिकेट नामों के साथ निम्नलिखित रिकॉर्ड हैं -

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
   8 | Paul  |  24 | Houston      |  20000
   9 | James |  44 | Norway       |   5000
  10 | James |  45 | Texas        |   5000
(10 rows)

निम्नलिखित उदाहरण है, जो रिकॉर्ड प्रदर्शित करेगा जिसके लिए नाम गणना 1 से अधिक है -

testdb-# SELECT NAME FROM COMPANY GROUP BY name HAVING count(name) > 1;

यह निम्नलिखित परिणाम का उत्पादन करेगा -

name
-------
 Paul
 James
(2 rows)