स्ट्रिंग्स के लिए MySQL Group Concat

Mysql Group Concat Strings



GROUP _CONCAT फ़ंक्शन एक ग्रुप बाय एग्रीगेट फ़ंक्शन है जो आपको कई पंक्तियों से कॉलम मानों को एक फ़ील्ड में संयोजित करने की अनुमति देता है। यह एक स्ट्रिंग देता है यदि सेट समूह में एक या नो-नल कॉलम मान होता है और यदि कोई नहीं मिल सकता है तो एक पूर्ण मान देता है।

यह ट्यूटोरियल आपको सिखाएगा कि एक समूह से कई विकल्पों के साथ स्ट्रिंग्स को संयोजित करने के लिए MySQL GROUP_CONCAT () फ़ंक्शन का उपयोग कैसे करें।







मूल उपयोग

जैसा कि हमने उल्लेख किया है, यह फ़ंक्शन एक स्ट्रिंग परिणाम देता है जिसमें गैर-शून्य मानों के मानों के साथ या कोई भी मौजूद नहीं होने पर NULL होता है।



सामान्य वाक्यविन्यास है:



GROUP_CONCAT ([ अलग ]एक्सप्रेस[,एक्सपीआर ...]
[ द्वारा आदेश एक्सप्रेस
[ एएससी | वर्णन ] [,col_name ...]]
[SEPARATOR str_val])

व्याख्या

उपरोक्त सिंटैक्स से, आप देख सकते हैं कि GROUP_CONCAT फ़ंक्शन विभिन्न विकल्पों को निर्दिष्ट करने के लिए MySQL क्लॉज़ और बाधाओं का उपयोग करता है:





  1. अलग: DISTINCT क्लॉज संयोजन प्रक्रिया से पहले सेट समूह में डुप्लिकेट मानों को हटाने में मदद करता है। यह कैसे काम करता है यह समझने के लिए MySQL DISTINCT को समझाते हुए हमारे ट्यूटोरियल पर विचार करें।
  2. द्वारा आदेश: अगला खंड ORDER BY है जो एक निर्दिष्ट क्रम में मानों को क्रमबद्ध करने में मदद करता है। क्रम या तो आरोही या अवरोही हो सकता है। यदि कोई आदेश निर्दिष्ट नहीं है, तो MySQL मानों को आरोही क्रम में स्वरूपित करता है।
  3. सेपरेटर : यह खंड संयोजन प्रक्रिया पर समूह के मूल्यों के बीच डाले गए स्ट्रिंग अक्षर को सेट करता है। डिफ़ॉल्ट रूप से, MySQL मानों को अलग करने के लिए अल्पविराम (,) का उपयोग करता है।

ध्यान दें: MySQL GROUP_CONCAT () फ़ंक्शन द्वारा उत्पन्न स्ट्रिंग परिणाम, group_concat_max_len चर में निर्धारित मान की लंबाई तक सीमित है। यह मान सिस्टम में परिभाषित है और इसका डिफ़ॉल्ट मान 1024 है। आप इस मान को विश्व स्तर पर बदल सकते हैं या इसे अपनी जरूरत के सत्र में सेट कर सकते हैं।

सेट [ ग्लोबल | सत्र ]group_concat_max_len= मूल्य ;

अधिक जानने के लिए नीचे दिए गए संदर्भ पर विचार करें:



https://dev.mysql.com/doc/refman/8.0/hi/server-system-variables.html#sysvar_group_concat_max_len

यह कैसे काम करता है: उदाहरण

GROUP_CONCAT() फ़ंक्शन कैसे काम करता है, यह समझाने के लिए मुझे एक सरल उदाहरण का उपयोग करने की अनुमति दें। CHAR के लिए एक फ़ील्ड वाली तालिका पर विचार करें:

सर्जन करना टेबल concat ( मूल्य CHAR );

आइए तालिका में मान डालें जैसा कि नीचे दी गई क्वेरी में दिखाया गया है:

सम्मिलित करें में concat ( मूल्य ) मान ('एच'),('तथा'),('NS'),('NS'),('या');

यदि हम तालिका में मूल्यों पर एक बुनियादी GROUP_CONCAT ऑपरेशन करते हैं, तो हमें नीचे दिखाए गए अनुसार एक स्ट्रिंग परिणाम मिलेगा:

चुनते हैं GROUP_CONCAT ( अलग मूल्य द्वारा आदेश मूल्य एएससी सेपरेटर'') से concat ;

परिणामी मूल्य है:

+ ------------------------------------------------- -------------- +
| GROUP_CONCAT ( अलग मूल्य द्वारा आदेश मूल्य एएससी सेपरेटर'') |
+ ------------------------------------------------- -------------- +
|ई एच एल ओ|
+ ------------------------------------------------- -------------- +
1पंक्ति में सेट (0.01सेकंड)

क्या आप यह समझने का एक और तरीका चाहते हैं कि ऊपर दिए गए परिणाम का क्या हुआ?

हम MySQL DISTINCT क्लॉज के कारण सभी डुप्लिकेट मानों को हटाकर शुरू करते हैं जो एक L को हटा देता है।

इसके बाद, हम (एएससी) में परिभाषित आरोही क्रम द्वारा ऑर्डर करने के लिए आगे बढ़ते हैं, जो स्ट्रिंग को रूप में बदल देता है

नमस्कार->एहलो

अंत में, हम सेट मानों के लिए विभाजक के रूप में एक स्थान का उपयोग करके संयोजन प्रक्रिया करते हैं, जिसके परिणामस्वरूप स्ट्रिंग E H L O {H, E, L, L O} से प्राप्त होता है।

उदाहरण उपयोग के मामले

आइए हम एक वास्तविक डेटाबेस लें और इसका उपयोग यह समझाने के लिए करें कि हम GROUP_CONCAT () फ़ंक्शन को कैसे कार्यान्वित कर सकते हैं। इस उदाहरण में, हम सकीला डेटाबेस और विशेष रूप से, सकीला डेटाबेस से एड्रेस टेबल का उपयोग करेंगे।

अपने उदाहरणों के लिए डेटाबेस डाउनलोड करने के लिए नीचे दिए गए संसाधन पर विचार करें:

https://dev.mysql.com/doc/index-other.html

सकीला डेटाबेस के एड्रेस टेबल में आपको डिस्ट्रिक्ट कॉलम मिलेगा। हम सभी अनूठे जिलों को एक पाइप से अलग कर सकते हैं जैसा कि नीचे दिए गए प्रश्न में दिखाया गया है:

चुनते हैं GROUP_CONCAT ( अलग जिला द्वारा आदेश जिला SEPARATOR'|') से शकीला.पता आप LIMIT 5;

उपरोक्त क्वेरी सभी DISTINCT जिलों को प्रदर्शित करेगी और उन्हें एक पाइप द्वारा अलग किए गए आरोही क्रम में क्रमित करेगी।

ध्यान दें: GROUP_CONCAT () फ़ंक्शन एक समग्र फ़ंक्शन है। इसलिए, यह आवश्यक है कि आप फ़ंक्शन के अंदर ORDER BY स्टेटमेंट निर्दिष्ट करें न कि SELECT स्टेटमेंट में।

निष्कर्ष

इस ट्यूटोरियल में चर्चा की गई MySQL GROUP_CONCAT () फ़ंक्शन एक उपयोगी फ़ंक्शन है जो आपको एक तालिका से अद्वितीय, क्रमबद्ध और व्यवस्थित डेटा बनाने की अनुमति देता है जिसमें डुप्लिकेट और अनियंत्रित डेटा हो सकता है।

अधिक जानने के लिए डॉक्स या हमारे अन्य MySQL ट्यूटोरियल पर विचार करें।