PostgreSQL - क्लाज के साथ

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

CTE क्वेरी होने के साथ, विशेष रूप से उपयोगी है जब सबक्वरी को कई बार निष्पादित किया जाता है। यह अस्थायी तालिकाओं के स्थान पर समान रूप से सहायक है। यह एक बार एकत्रीकरण की गणना करता है और हमें प्रश्नों में इसके नाम (कई बार हो सकता है) द्वारा इसका संदर्भ देने की अनुमति देता है।

क्लॉज के साथ इसे क्वेरी में उपयोग करने से पहले परिभाषित किया जाना चाहिए।

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

क्वेरी के साथ मूल सिंटैक्स निम्नानुसार है -

WITH
   name_for_summary_data AS (
      SELECT Statement)
   SELECT columns
   FROM name_for_summary_data
   WHERE conditions <=> (
      SELECT column
      FROM name_for_summary_data)
   [ORDER BY columns]

जहाँ name_for_summary_data विदाउट क्लॉज नाम दिया गया है। Name_for_summary_data मौजूदा तालिका नाम के समान हो सकता है और पूर्वता लेगा।

आप डेटा-संशोधित करने वाले कथनों (INSERT, UPDATE या DELETE) का उपयोग कर सकते हैं। यह आपको एक ही क्वेरी में कई अलग-अलग ऑपरेशन करने की अनुमति देता है।

के साथ पुनरावर्ती

पुनरावर्ती या श्रेणीबद्ध प्रश्नों के साथ, सीटीई का एक रूप है जहां एक सीटीई खुद को संदर्भित कर सकता है, अर्थात, एक क्वेरी अपने स्वयं के आउटपुट को संदर्भित कर सकती है, इसलिए नाम पुनरावर्ती।

उदाहरण

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

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)

अब, ऊपर दिए गए तालिका से रिकॉर्ड का चयन करने के लिए विथ क्लॉज़ का उपयोग करके एक प्रश्न लिखें, जो निम्नानुसार है -

With CTE AS
(Select
 ID
, NAME
, AGE
, ADDRESS
, SALARY
FROM COMPANY )
Select * From CTE;

ऊपर दिया गया 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)

अब, 20000 से कम सैलरी के योग को खोजने के लिए, क्लॉज़ के साथ RECRSIVE कीवर्ड का उपयोग करके एक क्वेरी लिखें, जो निम्नानुसार है -

WITH RECURSIVE t(n) AS (
   VALUES (0)
   UNION ALL
   SELECT SALARY FROM COMPANY WHERE SALARY < 20000
)
SELECT sum(n) FROM t;

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

sum
-------
 25000
(1 row)

चलिए नीचे दिखाए गए अनुसार क्लॉज़ के साथ डेटा संशोधित करने वाले कथनों का उपयोग करते हुए एक क्वेरी लिखते हैं।

सबसे पहले, तालिका Company1 के समान तालिका Company1 बनाएं। उदाहरण में क्वेरी प्रभावी रूप से कंपनी से Company1 की पंक्तियों को ले जाती है। DELETE में कंपनी से निर्दिष्ट पंक्तियों को हटा दिया जाता है, अपनी सामग्री को उसके पुनरावर्ती खंड के माध्यम से वापस कर देता है; और फिर प्राथमिक क्वेरी उस आउटपुट को पढ़ती है और उसे Company1 टेबल में सम्मिलित करती है -

CREATE TABLE COMPANY1(
   ID INT PRIMARY KEY     NOT NULL,
   NAME           TEXT    NOT NULL,
   AGE            INT     NOT NULL,
   ADDRESS        CHAR(50),
   SALARY         REAL
);

WITH moved_rows AS (
   DELETE FROM COMPANY
   WHERE
      SALARY >= 30000
   RETURNING *
)
INSERT INTO COMPANY1 (SELECT * FROM moved_rows);

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

INSERT 0 3

अब, तालिकाओं में रिकॉर्ड कंपनी और Company1 इस प्रकार हैं -

testdb=# SELECT * FROM COMPANY;
 id | name  | age |  address   | salary
----+-------+-----+------------+--------
  1 | Paul  |  32 | California |  20000
  2 | Allen |  25 | Texas      |  15000
  3 | Teddy |  23 | Norway     |  20000
  7 | James |  24 | Houston    |  10000
(4 rows)


testdb=# SELECT * FROM COMPANY1;
 id | name  | age | address | salary
----+-------+-----+-------------+--------
  4 | Mark  |  25 | Rich-Mond   |  65000
  5 | David |  27 | Texas       |  85000
  6 | Kim   |  22 | South-Hall  |  45000
(3 rows)