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

बिना सबक्वेरी के MySQL में ग्रुप बाय पर ऑर्डर को प्राथमिकता दें

परिभाषा के अनुसार, ORDER BY को बाद . संसाधित किया जाता है GROUP BY के साथ समूह बनाना। परिभाषा के अनुसार, किसी भी SELECT स्टेटमेंट को प्रोसेस करने का वैचारिक तरीका है:

  1. FROM क्लॉज में संदर्भित सभी तालिकाओं के कार्टेशियन उत्पाद की गणना करें
  2. परिणामों को फ़िल्टर करने के लिए FROM क्लॉज से शामिल होने के मानदंड लागू करें
  3. परिणामों को और अधिक फ़िल्टर करने के लिए WHERE क्लॉज में फ़िल्टर मानदंड लागू करें
  4. ग्रुप बाय क्लॉज के आधार पर परिणामों को सबसेट में समूहित करें, ऐसे प्रत्येक उपसमुच्चय के लिए परिणामों को एक पंक्ति में संक्षिप्त करें और किसी भी समग्र कार्यों के मूल्यों की गणना करें - SUM() , MAX() , AVG() , आदि -- ऐसे प्रत्येक उपसमुच्चय के लिए। ध्यान दें कि यदि कोई ग्रुप बाय क्लॉज निर्दिष्ट नहीं है, तो परिणामों को ऐसा माना जाता है जैसे कि एक एकल सबसेट है और कोई भी समग्र कार्य पूरे परिणाम सेट पर लागू होता है, इसे एक पंक्ति में संक्षिप्त करता है।
  5. HAVING क्लॉज के आधार पर अब-समूहित परिणामों को फ़िल्टर करें।
  6. परिणामों को ORDER BY खंड के आधार पर क्रमित करें।

GROUP BY क्लॉज के साथ SELECT के परिणाम सेट में केवल एक ही कॉलम की अनुमति है, निश्चित रूप से,

  • ग्रुप बाय क्लॉज में संदर्भित कॉलम
  • समग्र कार्य (जैसे MAX() )
  • शाब्दिक/स्थिरांक
  • उपरोक्त में से किसी से व्युत्पन्न अभिव्यक्तियाँ।

केवल टूटा हुआ SQL कार्यान्वयन select xxx,yyy,a,b,c FROM foo GROUP BY xxx,yyy जैसी चीज़ों की अनुमति देता है - कॉलम ए, बी और सी के संदर्भ अर्थहीन/अपरिभाषित हैं, यह देखते हुए कि अलग-अलग समूह एक ही पंक्ति में ढह गए हैं,



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. जावा में MySQL डेटा के साथ HTML ड्रॉपडाउन भरने का प्रयास करते समय त्रुटि आ रही है?

  2. रेल, MySQL और हिम तेंदुआ

  3. MySQL में माध्यिका की गणना कैसे करें

  4. एक ही क्वेरी का उपयोग कर mysql में सीमा के लिए कुल प्राप्त करें?

  5. `रैंड ()` का उपयोग `होने` के साथ