महीने दर महीने वृद्धि बिक्री, साइनअप आदि की तुलना में महीने दर महीने के लिए एक उपयोगी व्यावसायिक मीट्रिक KPI है। हम SQL क्वेरी के माध्यम से मासिक प्रतिशत वृद्धि की गणना करेंगे, क्योंकि इसके लिए कोई PostgreSQL फ़ंक्शन नहीं है। PostgreSQL में महीने दर महीने वृद्धि की गणना करने का तरीका यहां दिया गया है।
PostgreSQL में महीने दर महीने वृद्धि की गणना कैसे करें
मान लें कि आपके पास एक तालिका है जिसमें मासिक बिक्री शामिल है जिसे sales_data(माह, बिक्री) कहा जाता है
postgres=# create table sales_data(month int,sale int); postgres=# insert into sales_data(month,sale) values(1,2021), (2,2102),(3,2150),(4,2312),(5,2425); postgres=# select * from sales_data; month | sale -------+------ 1 | 2021 2 | 2102 3 | 2150 4 | 2312 5 | 2425
यहाँ PostgreSQL में बिक्री में महीने दर महीने प्रतिशत वृद्धि की गणना करने के लिए SQL क्वेरी है।
postgres=# select month,sum(sale) as current_sale, lag(sum(sale), 1) over (order by month) as previous_month_sale, (100 * (sum(sale) - lag(sum(sale), 1) over (order by month)) / lag(sum(sale), 1) over (order by month)) || '%' as growth from sales_data group by 1 order by 1; month | current_sale | previous_month_sale | growth -------+--------------+---------------------+-------- 1 | 2021 | | 2 | 2102 | 2021 | 4% 3 | 2150 | 2102 | 2% 4 | 2312 | 2150 | 7% 5 | 2425 | 2312 | 4%
उपरोक्त क्वेरी में, हम पिछले महीने की बिक्री की गणना करने के लिए LAG विंडो फ़ंक्शन का उपयोग करते हैं, और इसका उपयोग PostgreSQL में महीने दर महीने वृद्धि की गणना करने के लिए करते हैं। LAG आपको वर्तमान पंक्ति से पहले आने वाली पंक्ति को परिभाषित ऑफ़सेट पर लाने की अनुमति देता है, जो हमारे मामले में 1 है।
बोनस पढ़ें: पोस्टग्रेएसक्यूएल में पिवट टेबल कैसे बनाएं
ज्यादातर मामलों में, आपके पास मासिक संख्या के बजाय दैनिक बिक्री डेटा होगा। इस मामले में, हम पहले इसे मासिक बिक्री संख्या में एकत्रित करते हैं और फिर PostgreSQL में महीने दर महीने वृद्धि की गणना करने के लिए उपरोक्त SQL क्वेरी लागू करते हैं।
मान लें कि आपके पास दैनिक बिक्री डेटा है।
postgres=# create sales (order_date date, sale int); postgres=# insert into sales values('2020-01-01',20), ('2020-01-02',25),('2020-01-03',15),('2020-01-04',30), ('2020-02-05',20),('2020-02-10',20),('2020-02-06',25), ('2020-03-07',15),('2020-03-08',30),('2020-03-09',20); postgres=# select * from sales; order_date | sale | ------------+------+ 2020-01-01 | 20 | 2020-01-02 | 25 | 2020-01-03 | 15 | 2020-01-04 | 30 | 2020-02-05 | 20 | 2020-02-10 | 20 | 2020-02-06 | 25 | 2020-03-07 | 15 | 2020-03-08 | 30 | 2020-03-09 | 20 |
यहाँ PostgreSQL में मासिक वृद्धि दर की गणना करने के लिए SQL क्वेरी है
postgres=# select month,sum(sale) as current_sale, lag(sum(sale), 1) over (order by month) as previous_month_sale, round((100 * (sum(sale) - lag(sum(sale), 1) over (order by month)) / lag(sum(sale), 1) over (order by month)),2) || '%' as growth from (select to_char(order_date,'Mon') as month, sum(sale) as sale from sales group by 1 ) sales_data group by 1 order by 1; month | current_sale | previous_month_sale | growth -------+--------------+---------------------+--------- Feb | 65 | | Jan | 90 | 65 | 38.46% Mar | 65 | 90 | -27.78%
उपरोक्त क्वेरी में, हम दैनिक बिक्री डेटा को मासिक मानों (बोल्ड . में) में एकत्रित करते हैं ) और फिर पहले की क्वेरी का उपयोग करें।
PostgreSQL में महीने दर महीने वृद्धि की गणना करने से पहले, आप WHERE क्लॉज का उपयोग करके अपने डेटा को फ़िल्टर भी कर सकते हैं।
postgres=# select month,sum(sale) as current_sale, lag(sum(sale), 1) over (order by month) as previous_month_sale, round((100 * (sum(sale) - lag(sum(sale), 1) over (order by month)) / lag(sum(sale), 1) over (order by month)),2) || '%' as growth from (select to_char(order_date,'Mon') as month, sum(sale) as sale from sales WHERE condition group by 1 ) sales_data group by 1 order by 1;
PostgreSQL में महीने दर महीने वृद्धि की गणना करने के बाद, आप इस डेटा को बार चार्ट या डैशबोर्ड पर प्लॉट करने के लिए रिपोर्टिंग टूल का उपयोग कर सकते हैं और इसे अपनी टीम के साथ साझा कर सकते हैं। यहां एक बार चार्ट का उदाहरण दिया गया है, जो महीने दर महीने प्रतिशत वृद्धि दिखाता है, जिसे Ubiq का उपयोग करके बनाया गया है।
यदि आप PostgreSQL डेटाबेस से चार्ट, डैशबोर्ड और रिपोर्ट बनाना चाहते हैं, तो आप Ubiq को आज़मा सकते हैं। हम 14-दिन का निःशुल्क परीक्षण प्रदान करते हैं।