PostgreSQL
 sql >> डेटाबेस >  >> RDS >> PostgreSQL

PostgreSQL में मूविंग एवरेज की गणना कैसे करें

मूविंग एवरेज या रोलिंग एवरेज आपको पिछले 7 दिनों की तरह चलती अवधि में औसत की गणना करने की अनुमति देता है। दैनिक संख्याओं को ट्रैक करने की तुलना में समय के साथ चलती औसत की गणना करना आसान प्रवृत्ति देता है। यहाँ PostgreSQL में मूविंग एवरेज की गणना करने के लिए SQL क्वेरी है।

PostgreSQL में मूविंग एवरेज की गणना कैसे करें

यहां बताया गया है कि PostgreSQL में मूविंग एवरेज की गणना कैसे करें। मान लें कि आपके पास निम्न तालिका है

postgres=# create table sales(order_date date,sale int);

postgres=# insert into sales values('2020-04-01',210),
           ('2020-04-02',125),('2020-04-03',150),('2020-04-04',230),
           ('2020-04-05',200),('2020-04-10',220),('2020-04-06',25),
           ('2020-04-07',215),('2020-04-08',300),('2020-04-09',250);

postgres=# select * from sales;
 order_date | sale
------------+------
 2020-04-01 |  210
 2020-04-02 |  125
 2020-04-03 |  150
 2020-04-04 |  230
 2020-04-05 |  200
 2020-04-10 |  220
 2020-04-06 |   25
 2020-04-07 |  215
 2020-04-08 |  300
 2020-04-09 |  250

बोनस पढ़ें :PostgreSQL में CSV फ़ाइल कैसे आयात करें

मान लें कि आप पिछले 5 दिनों के लिए PostgreSQL में मूविंग एवरेज की गणना करना चाहते हैं। PostgreSQL आपको विंडो फ़ंक्शंस की मदद से रोलिंग औसत की गणना करने की अनुमति देता है। यहाँ पिछले 5 दिनों के लिए PostgreSQL में मूविंग एवरेज की गणना करने की क्वेरी है। हम इसे विस्तार से देखेंगे

SELECT a.order_date,a.sale, 
       AVG(a.sale)
       OVER(ORDER BY a.order_date ROWS BETWEEN 4 PRECEDING AND CURRENT ROW)
       AS avg_sales
       FROM sales a ;
 order_date | sale |      avg_sales
------------+------+----------------------
 2020-04-01 |  210 | 210.00
 2020-04-02 |  125 | 167.50
 2020-04-03 |  150 | 161.66
 2020-04-04 |  230 | 178.75
 2020-04-05 |  200 | 183.00
 2020-04-06 |   25 | 146.00
 2020-04-07 |  215 | 164.00
 2020-04-08 |  300 | 194.00
 2020-04-09 |  250 | 198.00
 2020-04-10 |  220 | 202.00

उपरोक्त क्वेरी में, AVG फ़ंक्शन बिक्री . के औसत मूल्य की गणना करता है कॉलम। जब हम इसे विंडो फ़ंक्शन OVER के साथ उपयोग करते हैं, तो यह केवल हमारे द्वारा परिभाषित समय विंडो के लिए औसत की गणना करता है।

PostgreSQL में मूविंग एवरेज की गणना करने के लिए, हम पहले ORDER BY क्लॉज का उपयोग करके पंक्तियों को कालानुक्रमिक रूप से क्रमबद्ध करते हैं। फिर हम 4 पूर्ववर्ती और वर्तमान पंक्ति के बीच पंक्तियों का उपयोग करके औसत की गणना के लिए हमारी विंडो को परिभाषित करते हैं। इसका मतलब है कि प्रत्येक पंक्ति के लिए केवल वर्तमान पंक्ति और पूर्ववर्ती 4 पंक्तियों के लिए औसत की गणना करें। इसलिए प्रत्येक पंक्ति के लिए केवल पिछले 5 दिनों के मूल्यों पर विचार किया जाता है।

आप उपरोक्त SQL क्वेरी में WHERE क्लॉज़ और ROUND फ़ंक्शन जोड़कर फ़िल्टर और गोल औसत मान भी जोड़ सकते हैं।

 SELECT a.order_date,a.sale, 
       round(AVG(a.sale)
       OVER(ORDER BY a.order_date ROWS BETWEEN 4 PRECEDING AND CURRENT ROW),2) 
       AS avg_sales
       FROM sales a
       WHERE condition;

बोनस पढ़ें:PostgreSQL में मासिक वृद्धि की गणना करें

PostgreSQL में 30-दिवसीय चलती औसत की गणना कैसे करें

इसी तरह, यदि आप PostgreSQL में 30-दिवसीय चलती औसत की गणना करना चाहते हैं, तो आप 29 पूर्ववर्ती पंक्तियों और वर्तमान पंक्ति पर विचार करके उपरोक्त क्वेरी को संशोधित कर सकते हैं।

SELECT a.order_date,a.sale, 
       AVG(a.sale)
       OVER(ORDER BY a.order_date ROWS BETWEEN 29 PRECEDING AND CURRENT ROW)
       AS avg_sales
       FROM sales a ;

PostgreSQL में 3 महीने के मूविंग एवरेज की गणना कैसे करें

यदि आपके पास दैनिक बिक्री डेटा है, और PostgreSQL में 3 महीने की चलती औसत की गणना करना चाहते हैं, तो आप 89 पूर्ववर्ती पंक्तियों और वर्तमान पंक्ति पर विचार करके उपरोक्त क्वेरी को संशोधित कर सकते हैं।

SELECT a.order_date,a.sale, 
       AVG(a.sale)
       OVER(ORDER BY a.order_date ROWS BETWEEN 89 PRECEDING AND CURRENT ROW)
       AS avg_sales
       FROM sales a ;

मान लें कि आपके पास दैनिक डेटा के बजाय मासिक डेटा है, और आप पिछले 3 महीनों के रोलिंग औसत की गणना करना चाहते हैं

postgres=# create table monthly_sales(order_month date,sale int);

postgres=# insert into monthly_sales values('2019-12-01',120),
           ('2020-01-30',250),('2020-02-28',150),('2020-03-31',300),
           ('2020-04-30',200),('2020-05-31',200),('2020-06-30',250),
           ('2020-07-31',150),('2020-08-31',300),('2020-09-30',200);

postgres=# select * from monthly_sales;
 order_month | sale
-------------+------
 2019-12-01  |  120
 2020-01-30  |  250
 2020-02-28  |  150
 2020-03-31  |  300
 2020-04-30  |  200
 2020-05-31  |  200
 2020-06-30  |  250
 2020-07-31  |  150
 2020-08-31  |  300
 2020-09-30  |  200

बोनस पढ़ें:SQL में अवधारण दर की गणना कैसे करें

हम PostgreSQL में रोलिंग औसत की गणना करने के लिए ऊपर के समान तर्क का उपयोग करते हैं। सबसे पहले, हम पंक्तियों को कालानुक्रमिक रूप से क्रमबद्ध करते हैं, और फिर दो पंक्तियों से पहले के लिए औसत की गणना करने के लिए ओवर विंडो फ़ंक्शन का उपयोग करते हैं। और वर्तमान पंक्ति

SELECT a.order_month,a.sale,
        round(AVG(a.sale)
        OVER(ORDER BY a.order_month ROWS BETWEEN 2 PRECEDING AND CURRENT ROW),2) 
        AS avg_sales
        FROM monthly_sales a ;

 order_month | sale | avg_sales
-------------+------+-----------
 2019-12-01  |  120 |    120.00
 2020-01-30  |  250 |    185.00
 2020-02-28  |  150 |    173.33
 2020-03-31  |  300 |    233.33
 2020-04-30  |  200 |    216.67
 2020-05-31  |  200 |    233.33
 2020-06-30  |  250 |    216.67
 2020-07-31  |  150 |    200.00
 2020-08-31  |  300 |    233.33
 2020-09-30  |  200 |    216.67

बोनस पढ़ें:PostgreSQL में पिवट टेबल कैसे बनाएं

आप उपरोक्त SQL क्वेरी में WHERE क्लॉज को शामिल करके फ़िल्टर भी जोड़ सकते हैं।

 SELECT a.order_month,a.sale,
        round(AVG(a.sale)
        OVER(ORDER BY a.order_month ROWS BETWEEN 2 PRECEDING AND CURRENT ROW),2) 
        AS avg_sales
        FROM monthly_sales a
        WHERE condition;

आप अपनी आवश्यकताओं के अनुसार, PostgreSQL में मूविंग एवरेज की गणना करने के लिए उपरोक्त क्वेरी को कस्टमाइज़ कर सकते हैं।

PostgreSQL में मूविंग एवरेज की गणना करने के बाद, आप चार्टिंग टूल का उपयोग करके इसे लाइन चार्ट पर प्लॉट कर सकते हैं और इसे अपनी टीम के साथ साझा कर सकते हैं। यहां एक लाइन चार्ट का उदाहरण दिया गया है जो Ubiq का उपयोग करके बनाए गए मूविंग एवरेज की कल्पना करता है।

यदि आप PostgreSQL डेटाबेस से चार्ट, डैशबोर्ड और रिपोर्ट बनाना चाहते हैं, तो आप Ubiq आज़मा सकते हैं। हम एक 14-दिवसीय नि:शुल्क परीक्षण की पेशकश करते हैं।


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. NodeJS और Postgres का उपयोग करके लेनदेन श्रृंखला में वैकल्पिक INSERT विवरण

  2. अद्यतन पर Postgresql वर्तमान टाइमस्टैम्प

  3. PostgreSQL उच्च उपलब्धता का प्रबंधन - भाग I:PostgreSQL स्वचालित विफलता

  4. रेक डीबी:थ्रो डेटाबेस बनाएं पोस्टग्रेस्क्ल के साथ त्रुटि मौजूद नहीं है

  5. PostgreSQL में EXCEPT क्लॉज का उपयोग करना