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

मैसकल का ग्रुप बाय और ओरेकल का ग्रुप बाय बिहेवियर अलग क्यों है

MySQL डिजाइनरों ने अपने गैर-मानक एक्सटेंशन को GROUP BY . में डाल दिया है विकास को आसान और कुछ प्रश्नों को अधिक कुशल बनाने के प्रयास में।

यहाँ उनका तर्क है।

https://dev.mysql.com/doc/refman/8.0/hi/group-by-handling.html

एक सर्वर मोड है जिसे ONLY_FULL_GROUP_BY . कहा जाता है जो गैरमानक एक्सटेंशन को निष्क्रिय कर देता है। आप इस कथन का उपयोग करके इस मोड को सेट कर सकते हैं।

 SET SESSION SQL_MODE='ONLY_FULL_GROUP_BY'  

यहाँ उस पृष्ठ से एक उद्धरण दिया गया है, जिसमें ज़ोर दिया गया है।

<ब्लॉकक्वॉट>

अगर ONLY_FULL_GROUP_BY अक्षम है, GROUP BY . के मानक SQL उपयोग के लिए एक MySQL एक्सटेंशन चयन सूची की अनुमति देता है, HAVING शर्त, या ORDER BY गैर-समेकित स्तंभों को संदर्भित करने के लिए सूची, भले ही स्तंभ कार्यात्मक रूप से GROUP BY पर निर्भर न हों कॉलम... इस मामले में, सर्वर प्रत्येक समूह से कोई भी मान चुनने के लिए स्वतंत्र है , इसलिए जब तक वे समान न हों, चुने गए मान गैर-निर्धारिती . हैं , जो शायद वह नहीं है जो आप चाहते हैं।

यहां महत्वपूर्ण शब्द है गैर नियतात्मक। इसका क्या मतलब है? इसका मतलब है यादृच्छिक, लेकिन बदतर। यदि सर्वर ने यादृच्छिक मान चुना है, तो इसका मतलब है कि यह अलग-अलग प्रश्नों में अलग-अलग मान लौटाएगा, इसलिए जब आप अपने सॉफ़्टवेयर का परीक्षण करते हैं तो आपके पास समस्या को पकड़ने का मौका होता है। लेकिन गैर नियतात्मक इस संदर्भ में इसका अर्थ है कि सर्वर हर बार एक ही मान चुनता है, जब तक वह ऐसा नहीं करता।

यह अपने द्वारा चुने गए मूल्य को क्यों बदल सकता है? एक सर्वर अपग्रेड एक कारण है। तालिका आकार में परिवर्तन एक और हो सकता है। मुद्दा यह है कि सर्वर जो भी मूल्य चाहता है उसे वापस करने के लिए स्वतंत्र है।

काश SQL सीखने वाले नए लोग यह ONLY_FULL_GROUP_BY सेट करते हैं तरीका; वे अपने प्रश्नों से बहुत अधिक अनुमानित परिणाम प्राप्त करेंगे, और सर्वर गैर-नियतात्मक प्रश्नों को अस्वीकार कर देगा।



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. टेबलस्पेस पर खाली जगह का पता लगाएं

  2. ओरेकल बाहरी टेबल

  3. Oracle अनुक्रमणिका अशक्त स्तंभ मान कब करता है?

  4. ओरेकल में खाली टेबल कैसे निर्यात करें?

  5. सभी उपयोगकर्ता तालिकाओं को कैसे छोड़ें?