एसएपी हाना व्यवस्थापक - टेबल विभाजन
विभाजन का उपयोग करते हुए, आप कॉलम स्टोर टेबल को कई होस्ट सिस्टम में छोटे तालिकाओं में विभाजित कर सकते हैं। आप विभाजन के उपयोग से तालिकाओं को छोटे अधिक प्रबंधनीय भागों में भी विभाजित कर सकते हैं। DML SQL कथनों का उपयोग करके विभाजन किया जा सकता है।
जब किसी तालिका का विभाजन होता है तो उसमें प्रत्येक भाग के लिए अलग-अलग पंक्तियों का समूह होता है और विभाजन अलग-अलग एल्गोरिदम - हैश विभाजन, एकल स्तर या बहुस्तरीय विभाजन के आधार पर किया जा सकता है।
तालिका विभाजन का उपयोग करने के निम्नलिखित फायदे हैं -
विभाजन प्रुनिंग
आप यह निर्धारित कर सकते हैं कि क्या किसी विशेष विभाजन में क्वेरी का विश्लेषण किया जा सकता है। इस पद्धति का उपयोग करके, आप सिस्टम पर लोड को कम कर सकते हैं और इसलिए प्रतिक्रिया समय में सुधार कर सकते हैं।
Example- जब आप वर्ष के आधार पर एक तालिका का विभाजन करते हैं, तो किसी विशेष वर्ष के लिए डेटा का विश्लेषण करने के लिए एक क्वेरी निष्पादित की जाती है। आप विशिष्ट विभाजन का उपयोग कर सकते हैं और इसलिए क्वेरी प्रदर्शन में सुधार किया जाता है।
भार संतुलन
आप कई विभाजनों पर अलग-अलग विभाजन को विभाजित कर सकते हैं और इसलिए एक क्वेरी को एक सर्वर द्वारा संसाधित नहीं किया जाता है, जिसके परिणामस्वरूप तालिका विभाजन की मेजबानी करने वाले सभी सर्वरों पर बेहतर लोड संतुलन होता है।
आकार सीमा
एक कॉलम स्टोर तालिका में, अधिकतम पंक्तियों को दर्ज किया जा सकता है जो लगभग 2 बिलियन है। आप कई विभाजनों पर एक स्तंभ तालिका की पंक्तियों को वितरित करके इसे दूर कर सकते हैं और इसलिए प्रत्येक विभाजन के लिए आकार की सीमा 2 बिलियन तक बढ़ जाती है।
बेहतर डेल्टा मर्ज ऑपरेशन
डेल्टा मर्ज के दौरान, यदि डेटा केवल कुछ विभाजन के लिए संशोधित किया गया है, तो आपको डेल्टा विलय में कम विभाजन को मर्ज करने की आवश्यकता है।
क्वेरी के समानांतर प्रसंस्करण
विभाजन का उपयोग करके, आप समानांतर में कई क्वेरी चला सकते हैं और इसलिए प्रतिक्रिया समय में सुधार कर सकते हैं।
आइए अब हम विभाजन के प्रकारों पर चर्चा करते हैं।
सिंगल लेवल पार्टिशनिंग
एसएपी हाना प्रणाली में विभिन्न प्रकार के एकल स्तर विभाजन उपलब्ध हैं -
- हैश विभाजन
- राउंड रॉबिन विभाजन
- श्रेणी विभाजन
हैश विभाजन में, लोड बैलेंसिंग करने के लिए पंक्तियों को समान रूप से वितरित किया जाता है। आपको इस विभाजन प्रकार में तालिका सामग्री के बारे में विस्तृत जानकारी की आवश्यकता नहीं है।
हाश विभाजन की तुलना में, राउंड रॉबिन में विभाजन विभाजन पंक्तियाँ समान रूप से प्रत्येक विभाजन में वितरित की जाती हैं और नई पंक्तियाँ समान रूप से प्रत्येक विभाजन को सौंपी जाती हैं।
राउंड रॉबिन का उपयोग करके तालिका के 4 विभाजन बनाने के लिए, आप निम्न एसक्यूएल प्रश्नों का उपयोग कर सकते हैं। कोई प्राथमिक कुंजी परिभाषित नहीं की जानी चाहिए।
CREATE COLUMN TABLE TABLENAME (a INT, b INT, c INT)
PARTITION BY ROUNDROBIN PARTITIONS 4
यह कमांड एक टेबल के 4 पार्टिशन बनाएगी।
CREATE COLUMN TABLE Table_Name (a INT, b INT, c INT, PRIMARY KEY (a,b))
PARTITION BY HASH (a, b) PARTITIONS 4
यह कॉलम पर 4 विभाजन बनाएगा a तथा b, और आपको कम से कम एक कॉलम निर्दिष्ट करने की आवश्यकता है।
श्रेणी विभाजन
श्रेणी विभाजन में, आप कुछ मानों के लिए समर्पित विभाजन बनाते हैं और आपको स्तंभों के विभाजन के लिए तालिका सामग्री का गहन ज्ञान होना चाहिए।
Example - प्रत्येक कैलेंडर माह के लिए एक विभाजन बनाना।
CREATE COLUMN TABLE TABLE_NAME (a INT, b INT, c INT, PRIMARY KEY (a,b))
PARTITION BY RANGE (a)
(PARTITION 1 <= VALUES < 10, PARTITION 10 <= VALUES < 20,
PARTITION VALUE = 50, PARTITION OTHERS)
यह 4 विभाजनों का निर्माण करेगा, विभाजन 1 से 10 के लिए एक, 10 से 20 तक 2 एन डी , मूल्य 50 के लिए 3 आरडी , और अन्य सभी मूल्यों के लिए 4 वें ।
बहुस्तरीय विभाजन
बहुस्तरीय विभाजन में, आप मुख्य स्तंभों को विभाजन स्तंभों के रूप में उपयोग करने के लिए एचएएसएच और रींग एकल स्तर विभाजन की सीमा को पार कर सकते हैं। बहुस्तरीय विभाजन का उपयोग करते हुए, आप एक स्तंभ को विभाजित कर सकते हैं जो प्राथमिक कुंजी नहीं है। बहुस्तरीय विभाजन का सबसे आम प्रकार हैHASH-Range Partitioning।
हैश-रेंज मल्टीलेवल विभाजन में, आप लोड संतुलन को लागू करने के लिए पहले स्तर पर हैश विभाजन को लागू करते हैं और टाइमबेड विभाजन को लागू करने के लिए दूसरे स्तर पर श्रेणी विभाजन को लागू करते हैं।
CREATE COLUMN TABLE Table_name (a INT, b INT, c INT, PRIMARY KEY (a,b))
PARTITION BY HASH (a, b) PARTITIONS 4,
RANGE (c) (PARTITION 1 <= VALUES < 10, PARTITION 10 <= VALUES < 20)
पहले स्तर पर हैश विभाजन का उपयोग करने के बजाय, आप राउंड रॉबिन विभाजन का भी उपयोग कर सकते हैं और इसे के रूप में जाना जाता है Round Robin-Range multilevel partitioning।
CREATE COLUMN TABLE Table_name (a INT, b INT, c INT)
PARTITION BY ROUNDROBIN PARTITIONS 4,
RANGE (c) (PARTITION 1 <= VALUES < 10, PARTITION 10 <= VALUES < 20)