- 1 1. Introduction
- 2 2. Basics of Counting Data in MySQL (COUNT)
- 3 3. Retrieving Data Without Duplicates (DISTINCT)
- 4 4. How to Use COUNT(DISTINCT column_name)
- 5 5. Using COUNT(DISTINCT) with Multiple Columns
- 6 6. COUNT(DISTINCT) के लिए प्रदर्शन ट्यूनिंग
- 7 7. COUNT(DISTINCT) के सामान्य त्रुटियाँ और समाधान
- 8 8. अक्सर पूछे जाने वाले प्रश्न (FAQ)
- 9 9. निष्कर्ष
1. Introduction
जब आप डेटाबेस का प्रबंधन करते हैं, तो आप ऐसी स्थितियों का सामना कर सकते हैं जैसे, “कितने अलग‑अलग देशों का पंजीकरण हुआ है?” या “कितने अनोखे ई‑मेल पते मौजूद हैं?”
ऐसे मामलों में आप MySQL की COUNT(DISTINCT column_name) का उपयोग करके डुप्लिकेट हटाते हुए रिकॉर्ड की संख्या प्राप्त कर सकते हैं।
यह लेख निम्नलिखित विषयों को विस्तार से समझाता है:
COUNT()औरDISTINCTकी मूल बातेंCOUNT(DISTINCT column_name)का सही उपयोग- कई कॉलम में अनोखे मानों की गिनती कैसे करें
COUNT(DISTINCT)के प्रदर्शन को कैसे बेहतर बनाएं
यह गाइड शुरुआती लोगों के लिए भी आसानी से समझने योग्य है, क्योंकि हम सब कुछ व्यावहारिक उदाहरणों और SQL क्वेरीज़ के साथ समझाते हैं। अंत तक पढ़ना न भूलें।
2. Basics of Counting Data in MySQL (COUNT)
डेटाबेस में डेटा का विश्लेषण करते समय सबसे बुनियादी फ़ंक्शन COUNT() है।
पहले समझते हैं कि COUNT() कैसे काम करता है।
2.1 Difference Between COUNT(*) and COUNT(column_name)
MySQL में COUNT() फ़ंक्शन को दो तरीकों से उपयोग किया जा सकता है:
| COUNT Function | Description |
|---|---|
COUNT(*) | Counts all records in the table (including NULL values) |
COUNT(column_name) | Counts non-NULL values in a specific column |
2.2 Basic COUNT() Examples
यहाँ हम निम्नलिखित users टेबल को उदाहरण के रूप में उपयोग करेंगे:
| id | name | country | |
|---|---|---|---|
| 1 | Taro | taro@example.com | Japan |
| 2 | Hanako | hanako@example.com | Japan |
| 3 | John | NULL | United States |
| 4 | Tanaka | tanaka@example.com | Japan |
① Retrieve the Total Number of Records in the Table
SELECT COUNT(*) FROM users;
→ Result: 4 (कुल रिकॉर्ड की संख्या)
② Retrieve the Number of Non-NULL Values in a Specific Column
SELECT COUNT(email) FROM users;
→ Result: 3 (नॉन‑NULL email मानों की संख्या)
💡 Key Points:
COUNT(*)कुल रिकॉर्ड की संख्या NULL मानों सहित प्राप्त करता है।COUNT(email)गिनती करते समय NULL मानों को बाहर रखता है।

3. Retrieving Data Without Duplicates (DISTINCT)
डेटा को एग्रीगेट करते समय अक्सर आप केवल अनोखे मानों को प्राप्त करना चाहते हैं। ऐसे मामलों में DISTINCT बहुत उपयोगी होता है।
3.1 Basics of DISTINCT
DISTINCT निर्दिष्ट कॉलम से डुप्लिकेट डेटा को हटाकर केवल अनोखे परिणाम लौटाता है।
Basic Syntax
SELECT DISTINCT column_name FROM table_name;
3.2 Example of Using DISTINCT
निम्नलिखित SQL क्वेरी चलाकर आप उपयोगकर्ताओं द्वारा पंजीकृत अनोखे देश नामों की सूची प्राप्त कर सकते हैं।
SELECT DISTINCT country FROM users;
→ Result:
| country |
|---|
| Japan |
| United States |
3.3 Difference Between DISTINCT and GROUP BY
| Feature | DISTINCT | GROUP BY |
|---|---|---|
| Purpose | Retrieve unique values | Perform aggregation by group |
| Usage | SELECT DISTINCT column_name | SELECT column_name, COUNT(*) GROUP BY column_name |
| Example | Retrieve unique countries | Count users per country |
💡 Key Points:
DISTINCTकेवल डुप्लिकेट डेटा को हटाता है।GROUP BYडेटा को समूहित करता है और एग्रीगेट फ़ंक्शन के साथ उपयोग किया जाता है।
4. How to Use COUNT(DISTINCT column_name)
COUNT(DISTINCT column_name) का उपयोग करके आप अनोखे मानों की संख्या प्राप्त कर सकते हैं।
4.1 Basics of COUNT(DISTINCT)
Basic Syntax
SELECT COUNT(DISTINCT column_name) FROM table_name;
4.2 Example of COUNT(DISTINCT)
SELECT COUNT(DISTINCT country) FROM users;
→ Result: 2 (दो प्रकार: “Japan” और “United States”)
4.3 Using COUNT(DISTINCT) with Conditions
SELECT COUNT(DISTINCT email) FROM users WHERE country = 'Japan';
→ Result: 2 (जापान में पंजीकृत अनोखे email मानों की संख्या)
💡 Key Points:
COUNT(DISTINCT column_name)NULL मानों को बाहर रखता है और केवल अनोड़े डेटा को गिनता है।WHEREक्लॉज़ का उपयोग करके आप विशिष्ट शर्तों को पूरा करने वाले रिकॉर्ड की गिनती कर सकते हैं।
5. Using COUNT(DISTINCT) with Multiple Columns
MySQL में COUNT(DISTINCT column1, column2) को सीधे उपयोग नहीं किया जा सकता। इसके बजाय एक सामान्य उपाय यह है कि कॉलमों को CONCAT() से जोड़कर उन्हें एकल मान के रूप में माना जाए।
5.1 Why COUNT(DISTINCT column1, column2) Cannot Be Used
MySQL में आप इस प्रकार कई कॉलमों पर सीधे COUNT(DISTINCT) लागू नहीं कर सकते: COUNT(DISTINCT column1, column2)।
यह MySQL की एक सीमा के कारण है।
5.2 How to Count Unique Combinations Across Multiple Columns
To count unique combinations of multiple columns, the typical approach is to combine the columns using CONCAT() and then apply COUNT(DISTINCT) to the result.
Example: Count Unique Combinations of Country and City
SELECT COUNT(DISTINCT CONCAT(country, '-', city)) FROM users;
💡 मुख्य बिंदु:
CONCAT(column1, '-', column2)का उपयोग करके आप कई कॉलमों को एक अद्वितीय मान में संयोजित कर सकते हैं।COUNT(DISTINCT CONCAT(...))आपको कई कॉलमों में अद्वितीय संयोजनों की संख्या प्राप्त करने में सक्षम बनाता है।
6. COUNT(DISTINCT) के लिए प्रदर्शन ट्यूनिंग
COUNT(DISTINCT) प्रदर्शन को प्रभावित कर सकता है, इसलिए अनुकूलन आवश्यक हो सकता है।
बड़े डेटा सेट के साथ काम करते समय, इंडेक्स या वैकल्पिक तरीकों का उपयोग करने पर विचार करने की सलाह दी जाती है।
6.1 क्यों COUNT(DISTINCT) धीमा हो सकता है
- MySQL अक्सर
DISTINCTलागू करने के लिए सभी रिकॉर्ड स्कैन करता है। - यदि इंडेक्स सही तरीके से कॉन्फ़िगर नहीं हैं, तो क्वेरी निष्पादन धीमा हो जाता है।
- डुप्लिकेट डेटा की बड़ी मात्रा गणनात्मक लोड को बढ़ाती है।
6.2 COUNT(DISTINCT) को तेज़ करने के लिए इंडेक्स अनुकूलन
बड़े डेटा को संभालते समय, आप लक्षित कॉलम में इंडेक्स जोड़कर क्वेरी प्रदर्शन को सुधार सकते हैं।
इंडेक्स कैसे जोड़ें
ALTER TABLE users ADD INDEX (country);
इंडेक्स का उपयोग करके क्वेरी निष्पादन योजना जांचें
EXPLAIN SELECT COUNT(DISTINCT country) FROM users;
💡 मुख्य बिंदु:
EXPLAINका उपयोग करके आप जांच सकते हैं कि MySQL क्वेरी को कैसे प्रोसेस करता है।- इंडेक्स लागू करने से पूरे टेबल स्कैन से बचा जा सकता है और खोज प्रदर्शन में सुधार हो सकता है।
6.3 वैकल्पिक विधि: GROUP BY + COUNT
एग्रीगेशन की आवश्यकता के आधार पर, GROUP BY का उपयोग बेहतर प्रदर्शन प्रदान कर सकता है।
उदाहरण: GROUP BY का उपयोग करके अद्वितीय डेटा की गिनती
SELECT country, COUNT(*) FROM users GROUP BY country;
💡 मुख्य बिंदु:
- कुछ मामलों में
GROUP BYCOUNT(DISTINCT)की तुलना में बेहतर प्रदर्शन प्रदान कर सकता है। - यह विशेष रूप से उपयोगी है जब आपको डेटा को एक साथ समूहित और एग्रीगेट करना हो।
7. COUNT(DISTINCT) के सामान्य त्रुटियाँ और समाधान
COUNT(DISTINCT) का उपयोग करते समय, आप कई सामान्य त्रुटियों का सामना कर सकते हैं।
यहाँ हम सामान्य समस्याओं और उनके समाधान प्रस्तुत करते हैं।
7.1 त्रुटि 1: COUNT(DISTINCT column1, column2) का उपयोग नहीं किया जा सकता
त्रुटि का कारण
MySQL में, जब कई कॉलम लक्षित होते हैं, तो COUNT(DISTINCT column1, column2) समर्थित नहीं है।
इस सिंटैक्स को सीधे उपयोग करने से त्रुटि उत्पन्न होगी।
समाधान: CONCAT() का उपयोग करें
आप कई कॉलमों को मिलाकर और परिणाम पर COUNT(DISTINCT) लागू करके इस त्रुटि से बच सकते हैं।
SELECT COUNT(DISTINCT CONCAT(country, '-', city)) FROM users;
💡 मुख्य बिंदु:
CONCAT(column1, '-', column2)का उपयोग करके आप कई कॉलमों से अद्वितीय मान बना सकते हैं।COUNT(DISTINCT CONCAT(...))आपको प्रत्येक संयोजन के लिए अद्वितीय मान प्राप्त करने में सक्षम बनाता है।
7.2 त्रुटि 2: NULL मान शामिल होने पर अप्रत्याशित परिणाम
त्रुटि का कारण
COUNT(DISTINCT column_name)NULL मानों को अनदेखा करता है, जिससे यदि कॉलम में NULL हों तो अप्रत्याशित परिणाम हो सकते हैं।
समाधान: IFNULL() का उपयोग करें
आप NULL को किसी अन्य डिफ़ॉल्ट मान (जैसे '' या 'unknown') से बदल सकते हैं ताकि सही गिनती सुनिश्चित हो सके।
SELECT COUNT(DISTINCT IFNULL(email, 'unknown')) FROM users;
💡 मुख्य बिंदु:
IFNULL(column_name, 'default_value')का उपयोग करके आप NULL मानों को उचित रूप से संभाल सकते हैं।
7.3 त्रुटि 3: COUNT(DISTINCT) धीमा है
त्रुटि का कारण
COUNT(DISTINCT)सभी डेटा को स्कैन करता है, जिससे बड़े डेटा सेट पर प्रदर्शन धीमा हो सकता है।
समाधान: इंडेक्स का उपयोग करें
ALTER TABLE users ADD INDEX (country);
💡 मुख्य बिंदु:
- इंडेक्स जोड़ने से क्वेरी प्रदर्शन में सुधार हो सकता है।
- क्वेरी अनुकूलन स्थिति जांचने के लिए
EXPLAINका उपयोग करें।EXPLAIN SELECT COUNT(DISTINCT country) FROM users;
By applying these measures, you can enhance the practicality of COUNT(DISTINCT) and avoid performance issues.
8. अक्सर पूछे जाने वाले प्रश्न (FAQ)
यहाँ COUNT(DISTINCT) के बारे में कुछ अक्सर पूछे जाने वाले प्रश्न हैं।
8.1 COUNT(*) और COUNT(DISTINCT column_name) में क्या अंतर है?
मुख्य अंतर
| Function | Description |
|---|---|
COUNT(*) | Counts all records (including NULL values) |
COUNT(DISTINCT column_name) | Counts unique values (excluding NULL values) |
उदाहरण उपयोग
SELECT COUNT(*) FROM users;
SELECT COUNT(DISTINCT email) FROM users;
💡 मुख्य बिंदु:
COUNT(*)सभी रिकॉर्ड गिनता है .COUNT(DISTINCT column_name)अद्वितीय मानों की संख्या प्राप्त करता है (NULL को छोड़कर) .
8.2 DISTINCT और GROUP BY में क्या अंतर है?
| Feature | DISTINCT | GROUP BY |
|---|---|---|
| Purpose | Retrieve unique values | Perform aggregation by group |
| Usage | SELECT DISTINCT column_name | SELECT column_name, COUNT(*) GROUP BY column_name |
| Example | Retrieve unique countries | Count users per country |
उदाहरण उपयोग
-- Using DISTINCT
SELECT DISTINCT country FROM users;
-- Using GROUP BY
SELECT country, COUNT(*) FROM users GROUP BY country;
💡 मुख्य बिंदु:
DISTINCTसिर्फ डुप्लिकेट डेटा को हटाता है .GROUP BYडेटा को समूहित करता है और इसे एग्रीगेट फ़ंक्शन्स के साथ जोड़ा जा सकता है .
8.3 क्या COUNT(DISTINCT) धीमा है?
समस्या
COUNT(DISTINCT)सभी डेटा को स्कैन करता है , इसलिए बड़े डेटासेट के साथ प्रदर्शन घट सकता है।
समाधान: इंडेक्स का उपयोग करें
ALTER TABLE users ADD INDEX (country);
वैकल्पिक तरीका: GROUP BY का उपयोग करें
SELECT country, COUNT(*) FROM users GROUP BY country;
💡 मुख्य बिंदु:
- इंडेक्स लागू करने से खोज प्रदर्शन में सुधार हो सकता है .
- कुछ मामलों में
GROUP BYका उपयोगCOUNT(DISTINCT)की तुलना में तेज़ परिणाम दे सकता है।
8.4 मैं COUNT(DISTINCT column1, column2) का उपयोग कैसे कर सकता हूँ?
समस्या
- MySQL में,
COUNT(DISTINCT column1, column2)समर्थित नहीं है .
समाधान: CONCAT() का उपयोग करें
SELECT COUNT(DISTINCT CONCAT(country, '-', city)) FROM users;
💡 मुख्य बिंदु:
CONCAT(column1, '-', column2)का उपयोग करने से आप कई कॉलमों में अद्वितीय मान बना सकते हैं ।COUNT(DISTINCT CONCAT(...))आपको अद्वितीय संयोजन प्राप्त करने में सक्षम बनाता है।
इन प्रश्नों को देख कर, आप COUNT(DISTINCT) का अधिक कुशलता से उपयोग कर सकते हैं।
9. निष्कर्ष
इस लेख में, हमने विस्तार से बताया कि MySQL के COUNT(DISTINCT) फ़ंक्शन का कैसे उपयोग किया जाता है।
चलिए मुख्य बिंदुओं की समीक्षा करते हैं।
9.1 इस लेख में आपने क्या सीखा
✅ MySQL में रिकॉर्ड कैसे गिनें
COUNT(*)कुल रिकॉर्ड संख्या प्राप्त करता हैCOUNT(column_name)NULL को छोड़कर मानों की गिनती करता हैCOUNT(DISTINCT column_name)अद्वितीय मानों की संख्या प्राप्त करता है
✅ DISTINCT और COUNT(DISTINCT) में अंतर
DISTINCTडुप्लिकेट हटाकर डेटा प्राप्त करता हैCOUNT(DISTINCT column_name)अद्वितीय मानों की संख्या गिनता है
✅ COUNT(DISTINCT) को कई कॉलमों के साथ कैसे उपयोग करें
- चूँकि MySQL सीधे
COUNT(DISTINCT column1, column2)का समर्थन नहीं करता, इसलिएCONCAT()का उपयोग करें
✅ प्रदर्शन अनुकूलन तकनीकें
- इंडेक्स लागू करें ताकि खोज प्रदर्शन सुधरे
- उपयुक्त होने पर तेज़ क्वेरी के लिए
GROUP BY + COUNTका उपयोग करें
9.2 इस ज्ञान से आप क्या कर सकते हैं
इस ज्ञान को लागू करके, आप निम्न प्रकार के डेटा एग्रीगेशन कर सकते हैं:
🔹 अद्वितीय उपयोगकर्ताओं की गिनती
🔹 विशिष्ट शर्तों के आधार पर रिकॉर्ड गिनती प्राप्त करना
🔹 कई कॉलमों में अद्वितीय डेटा की गिनती
🔹 बड़े डेटासेट के लिए क्वेरी को अनुकूलित करना
MySQL में डेटा एग्रीगेशन और अनुकूलन करते समय, इस गाइड को संदर्भ के रूप में अवश्य उपयोग करें!


