अवधारण दर को उन ग्राहकों की संख्या के रूप में परिभाषित किया जाता है जो किसी उत्पाद/सेवा का उपयोग करना जारी रखते हैं। कोहोर्ट प्रतिधारण विश्लेषण की गणना करना कठिन है। ग्राहक प्रतिधारण विश्लेषण के लिए SQL में अवधारण दर की गणना करने का तरीका यहां दिया गया है। आप इसका उपयोग MySQL, PostgreSQL, SQL Server और Oracle में अवधारण दर की गणना के लिए कर सकते हैं। हम ग्राहक प्रतिधारण के लिए SQL क्वेरी को भी देखेंगे। प्रतिधारण दर को नियमित अंतराल पर लौटने वाले उपयोगकर्ताओं की संख्या के रूप में मापा जाता है, जैसे कि हर सप्ताह या महीने, उनके साइनअप के सप्ताह के आधार पर समूहीकृत किया जाता है।
हम SQL में साप्ताहिक कोहोर्ट द्वारा प्रतिधारण की गणना करेंगे और नीचे दी गई तालिका जैसी तालिका के साथ समाप्त करेंगे, जो साइन अप करने के प्रत्येक सप्ताह के लिए कुछ सप्ताह पहले पहली बार साइन अप करने के बाद फिर से लॉग इन करने वाले ग्राहकों की संख्या दिखाती है।
SQL में अवधारण दर की गणना कैसे करें?
यहाँ SQL में अवधारण दर की गणना करने के चरण दिए गए हैं। मान लें कि आपके पास निम्न तालिका है जो प्रत्येक उपयोगकर्ता की विज़िट के user_id और login_date को संग्रहीत करती है।
mysql> create table login(login_date date,user_id int, id int not null auto_increment, primary key (id)); mysql> insert into login(login_date,user_id) values('2020-01-01',10),('2020-01-02',12),('2020-01-03',15), ('2020-01-04',11),('2020-01-05',13),('2020-01-06',9), ('2020-01-07',21),('2020-01-08',10),('2020-01-09',10), ('2020-01-10',2),('2020-01-11',16),('2020-01-12',12), ('2020-01-13',10),('2020-01-14',18),('2020-01-15',15), ('2020-01-16',12),('2020-01-17',10),('2020-01-18',18), ('2020-01-19',14),('2020-01-20',16),('2020-01-21',12), ('2020-01-22',21),('2020-01-23',13),('2020-01-24',15), ('2020-01-25',20),('2020-01-26',14),('2020-01-27',16), ('2020-01-28',15),('2020-01-29',10),('2020-01-30',18); mysql> select * from login; +------------+---------+----+ | login_date | user_id | id | +------------+---------+----+ | 2020-01-01 | 10 | 1 | | 2020-01-02 | 12 | 2 | | 2020-01-03 | 15 | 3 | | 2020-01-04 | 11 | 4 | | 2020-01-05 | 13 | 5 | | 2020-01-06 | 9 | 6 | | 2020-01-07 | 21 | 7 | | 2020-01-08 | 10 | 8 | | 2020-01-09 | 10 | 9 | | 2020-01-10 | 2 | 10 | | 2020-01-11 | 16 | 11 | | 2020-01-12 | 12 | 12 | | 2020-01-13 | 10 | 13 | | 2020-01-14 | 18 | 14 | | 2020-01-15 | 15 | 15 | | 2020-01-16 | 12 | 16 | | 2020-01-17 | 10 | 17 | | 2020-01-18 | 18 | 18 | | 2020-01-19 | 14 | 19 | | 2020-01-20 | 16 | 20 | | 2020-01-21 | 12 | 21 | | 2020-01-22 | 21 | 22 | | 2020-01-23 | 13 | 23 | | 2020-01-24 | 15 | 24 | | 2020-01-25 | 20 | 25 | | 2020-01-26 | 14 | 26 | | 2020-01-27 | 16 | 27 | | 2020-01-28 | 15 | 28 | | 2020-01-29 | 10 | 29 | | 2020-01-30 | 18 | 30 | +------------+---------+----+
हम साप्ताहिक कोहोर्ट विश्लेषण तैयार करेंगे। अपने उत्पाद/सेवा के आधार पर आप इसे मासिक/दैनिक में बदल सकते हैं।
हम SQL में अवधारण दर की गणना करने के लिए MySQL का उपयोग करेंगे। आप PostgreSQL के लिए मंथन दर की गणना भी कर सकते हैं।
<एच2>1. सप्ताह के अनुसार बकेट विज़िट
SQL में अवधारण दर की गणना करने के लिए, सबसे पहले, हम प्रत्येक विज़िट को उसके लॉगिन के सप्ताह के अनुसार समूहित करेंगे।
mysql> SELECT user_id, week(login_date) AS login_week FROM login GROUP BY user_id,week(login_date); +---------+------------+ | user_id | login_week | +---------+------------+ | 2 | 1 | | 9 | 1 | | 10 | 0 | | 10 | 1 | | 10 | 2 | | 10 | 4 | | 11 | 0 | | 12 | 0 | | 12 | 2 | | 12 | 3 | | 13 | 1 | | 13 | 3 | | 14 | 3 | | 14 | 4 | | 15 | 0 | | 15 | 2 | | 15 | 3 | | 15 | 4 | | 16 | 1 | | 16 | 3 | | 16 | 4 | | 18 | 2 | | 18 | 4 | | 20 | 3 | | 21 | 1 | | 21 | 3 | +---------+------------+
यह भी देखें कि MySQL में साप्ताहिक सक्रिय उपयोगकर्ताओं (WAU) की गणना कैसे करें।
2. प्रत्येक उपयोगकर्ता के लिए लॉगिन के पहले सप्ताह की गणना करें
अगला, SQL में अवधारण दर की गणना करने के लिए, हमें प्रत्येक उपयोगकर्ता के लिए लॉगिन के पहले सप्ताह की गणना करने की आवश्यकता है। हम प्रत्येक उपयोगकर्ता के लिए पहले लॉगिन सप्ताह की गणना करने के लिए केवल MIN फ़ंक्शन और GROUP BY का उपयोग करेंगे
mysql> SELECT user_id, min(week(login_date)) AS first_week FROM login GROUP BY user_id; +---------+------------+ | user_id | first_week | +---------+------------+ | 2 | 1 | | 9 | 1 | | 10 | 0 | | 11 | 0 | | 12 | 0 | | 13 | 1 | | 14 | 3 | | 15 | 0 | | 16 | 1 | | 18 | 2 | | 20 | 3 | | 21 | 1 | +---------+------------+
3. login_week और first_week के लिए 2 टेबल मर्ज करें
इसके बाद, SQL में अवधारण दर की गणना करने के लिए, हम नीचे दी गई क्वेरी का उपयोग करने वाले प्रत्येक उपयोगकर्ता के लिए एक INNER JOIN के साथ login_week और first_week साथ-साथ प्राप्त करते हैं।
mysql> select a.user_id,a.login_week,b.first_week as first_week from (SELECT user_id, week(login_date) AS login_week FROM login GROUP BY user_id,week(login_date)) a, (SELECT user_id, min(week(login_date)) AS first_week FROM login GROUP BY user_id) b where a.user_id=b.user_id; +---------+------------+------------+ | user_id | login_week | first_week | +---------+------------+------------+ | 2 | 1 | 1 | | 9 | 1 | 1 | | 10 | 0 | 0 | | 10 | 1 | 0 | | 10 | 2 | 0 | | 10 | 4 | 0 | | 11 | 0 | 0 | | 12 | 0 | 0 | | 12 | 2 | 0 | | 12 | 3 | 0 | | 13 | 1 | 1 | | 13 | 3 | 1 | | 14 | 3 | 3 | | 14 | 4 | 3 | | 15 | 0 | 0 | | 15 | 2 | 0 | | 15 | 3 | 0 | | 15 | 4 | 0 | | 16 | 1 | 1 | | 16 | 3 | 1 | | 16 | 4 | 1 | | 18 | 2 | 2 | | 18 | 4 | 2 | | 20 | 3 | 3 | | 21 | 1 | 1 | | 21 | 3 | 1 | +---------+------------+------------+
4. सप्ताह संख्या की गणना करें
यहाँ से, SQL में अवधारण दर की गणना करना आसान है। इसके बाद, हम सप्ताह_संख्या (सप्ताह की संख्या) की गणना करने के लिए login_week और first_week के बीच के अंतर की गणना करते हैं
mysql> select a.user_id,a.login_week,b.first_week as first_week, a.login_week-first_week as week_number from (SELECT user_id, week(login_date) AS login_week FROM login GROUP BY user_id,week(login_date)) a, (SELECT user_id, min(week(login_date)) AS first_week FROM login GROUP BY user_id) b where a.user_id=b.user_id; +---------+------------+------------+-------------+ | user_id | login_week | first_week | week_number | +---------+------------+------------+-------------+ | 2 | 1 | 1 | 0 | | 9 | 1 | 1 | 0 | | 10 | 0 | 0 | 0 | | 10 | 1 | 0 | 1 | | 10 | 2 | 0 | 2 | | 10 | 4 | 0 | 4 | | 11 | 0 | 0 | 0 | | 12 | 0 | 0 | 0 | | 12 | 2 | 0 | 2 | | 12 | 3 | 0 | 3 | | 13 | 1 | 1 | 0 | | 13 | 3 | 1 | 2 | | 14 | 3 | 3 | 0 | | 14 | 4 | 3 | 1 | | 15 | 0 | 0 | 0 | | 15 | 2 | 0 | 2 | | 15 | 3 | 0 | 3 | | 15 | 4 | 0 | 4 | | 16 | 1 | 1 | 0 | | 16 | 3 | 1 | 2 | | 16 | 4 | 1 | 3 | | 18 | 2 | 2 | 0 | | 18 | 4 | 2 | 2 | | 20 | 3 | 3 | 0 | | 21 | 1 | 1 | 0 | | 21 | 3 | 1 | 2 | +---------+------------+------------+-------------+
5. परिणाम पिवट करें
अंत में, हमें परिणाम को पिवट करने की आवश्यकता है, SQL में अवधारण दर की गणना करने के लिए, और कोहोर्ट तालिका उत्पन्न करने के लिए। हमारी पिवट तालिका में, हमारे पास प्रत्येक पहले_सप्ताह . के लिए एक पंक्ति होगी मान, और प्रत्येक सप्ताह_संख्या . के लिए एक कॉलम जिसमें आपके उत्पाद/सेवा का उपयोग करने के लिए 'n' सप्ताह के बाद वापस आने वाले उपयोगकर्ताओं की संख्या शामिल है। इसके लिए हम निम्नलिखित क्वेरी का उपयोग करते हैं।
mysql> select first_week, SUM(CASE WHEN week_number = 0 THEN 1 ELSE 0 END) AS week_0, SUM(CASE WHEN week_number = 1 THEN 1 ELSE 0 END) AS week_1, SUM(CASE WHEN week_number = 2 THEN 1 ELSE 0 END) AS week_2, SUM(CASE WHEN week_number = 3 THEN 1 ELSE 0 END) AS week_3, SUM(CASE WHEN week_number = 4 THEN 1 ELSE 0 END) AS week_4, SUM(CASE WHEN week_number = 5 THEN 1 ELSE 0 END) AS week_5, SUM(CASE WHEN week_number = 6 THEN 1 ELSE 0 END) AS week_6, SUM(CASE WHEN week_number = 7 THEN 1 ELSE 0 END) AS week_7, SUM(CASE WHEN week_number = 8 THEN 1 ELSE 0 END) AS week_8, SUM(CASE WHEN week_number = 9 THEN 1 ELSE 0 END) AS week_9 from ( select a.user_id,a.login_week,b.first_week as first_week,a.login_week-first_week as week_number from (SELECT user_id, week(login_date) AS login_week FROM login GROUP BY user_id,week(login_date)) a,(SELECT user_id, min(week(login_date)) AS first_week FROM login GROUP BY user_id) b where a.user_id=b.user_id ) as with_week_number group by first_week order by first_week; +------------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+ | first_week | week_0 | week_1 | week_2 | week_3 | week_4 | week_5 | week_6 | week_7 | week_8 | week_9 | +------------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+ | 0 | 4 | 1 | 3 | 2 | 2 | 0 | 0 | 0 | 0 | 0 | | 1 | 5 | 0 | 3 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | 2 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 3 | 2 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | +------------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+
अब हम जानते हैं कि SQL में अवधारण दर की गणना कैसे करें। आप उपरोक्त प्रश्नों को MySQL, PostgreSQL में अवधारण दर की गणना करने के लिए भी कर सकते हैं।
अंत में, आप डेटा विज़ुअलाइज़ेशन टूल का उपयोग तालिका में उपरोक्त प्रतिधारण कोहोर्ट विश्लेषण को प्लॉट करने के लिए कर सकते हैं। यूबीक का उपयोग करके बनाई गई एक कोहॉर्ट प्रतिधारण तालिका यहां दी गई है।
पी>
वैसे, यदि आप MySQL डेटाबेस से पिवट टेबल, चार्ट और डैशबोर्ड बनाना चाहते हैं, तो आप Ubiq को आज़मा सकते हैं। हम 14-दिन का निःशुल्क परीक्षण प्रदान करते हैं।