ऐसा इसलिए है क्योंकि ग्रुप बाय क्लॉज के बिना MySQL द्वारा लौटाया गया आउटपुट गुमराह कर सकता है। हम इसे प्रदर्शित करने के लिए नीचे दी गई 'छात्र' तालिका पर निम्नलिखित उदाहरण दे रहे हैं -
mysql> Select * from Student; +------+---------+---------+-----------+ | Id | Name | Address | Subject | +------+---------+---------+-----------+ | 1 | Gaurav | Delhi | Computers | | 2 | Aarav | Mumbai | History | | 15 | Harshit | Delhi | Commerce | | 20 | Gaurav | Jaipur | Computers | +------+---------+---------+-----------+ 4 rows in set (0.00 sec) mysql> Select count(*), Name from Student; +----------+--------+ | count(*) | name | +----------+--------+ | 4 | Gaurav | +----------+--------+ 1 row in set (0.00 sec)
जैसा कि हम उपरोक्त क्वेरी के परिणाम से देख सकते हैं कि यह समूह फ़ंक्शन COUNT (*) के आउटपुट को तालिका में पंक्तियों की कुल संख्या के रूप में देता है लेकिन 'नाम' फ़ील्ड में मान 'गौरव' भ्रामक है क्योंकि हम किस आधार पर करते हैं , या तो यह कॉलम का पहला मान है या इसे कई बार कॉलम में संग्रहीत किया जाता है, MySQL इसे वापस कर देता है।
अब अगर हम इस क्वेरी को ग्रुप बाय क्लॉज के साथ लिखेंगे तो परिणाम सेट इस प्रकार है -
mysql> Select count(*), name from student GROUP BY id; +----------+---------+ | count(*) | name | +----------+---------+ | 1 | Gaurav | | 1 | Aarav | | 1 | Harshit | | 1 | Gaurav | +----------+---------+ 4 rows in set (0.00 sec)
उपरोक्त परिणाम सेट से यह देखा जा सकता है कि ग्रुप बाय क्लॉज की मदद से हमें एक सार्थक आउटपुट मिला।