tsql प्रश्न लिखते समय इंडेक्स ट्यूनिंग सीखने का सबसे अच्छा व्यावहारिक तरीका क्या है? मेरे पास वीएस -2008 एसक्यूएल एक्सप्रेस है। क्या कोई मुझे उदाहरण प्रदान कर सकता है, इत्यादि? मुझे पहले से ही ऑनलाइन लेख मिल चुके हैं और वे सिद्धांत में महान हैं, लेकिन मैं अभी भी वास्तविक जीवन कार्रवाई में इंडेक्स ट्यूनिंग देखने में असफल रहा हूं। क्या वहां उदाहरण बनाने के लिए बहुत आसान है?मैं SQL सर्वर इंडेक्स ट्यूनिंग कैसे सीख सकता हूं?
उत्तर
इंडेक्स को ट्यून करने के लिए, आपको बहुत सारे डेटा के साथ बड़ी टेबल की आवश्यकता होती है, इसलिए छोटे सरल उदाहरण आने में आसान नहीं होते हैं।
मेरा अनुभव एसक्यूएल 2000 उपकरणों के साथ है। क्वेरी विश्लेषक, निष्पादन योजना दिखा रहा है और इंडेक्स के प्रकारों को देख रहा है और उपयोग में शामिल हो गया है। यहां इसका वर्णन करना बहुत मुश्किल है।
मैं, इस विषय पर एक अच्छी किताब की सिफारिश कर सकते विशेष रूप से अध्याय 9.
http://www.amazon.com/Professional-Server-Performance-Tuning-Programmer/dp/0470176393
मैं स्वचालित सूचकांक ट्यूनिंग उपकरण का उपयोग करने से हतोत्साहित होगा जब तक आप इसे अपने आप को ऐसा करने के लिए मैन्युअल रूप से समझते हैं। मुझे लगता है कि यह महत्वपूर्ण है जब यह एक इंडेक्स जोड़ने की सिफारिश करता है कि आपके पास स्वच्छता की क्षमता है-सिफारिश की जांच करें और खुद के लिए निर्णय लें कि यह एक अच्छा विकल्प है या नहीं। अक्सर यह सलाह दी जाएगी कि आप एक कॉलम को "कॉलिंग" इंडेक्स जोड़ दें ताकि आपके द्वारा विश्लेषण किए जाने वाले एक प्रश्न को तेज़ किया जा सके, लेकिन जब आप उस तालिका के विरुद्ध सभी प्रश्नों को देखते हैं तो इसका आपके डेटाबेस पर प्रतिकूल प्रभाव पड़ सकता है।
आप SQL डेवलपर संस्करण है, तो आप डेटाबेस इंजन ट्यूनिंग सलाहकार पर एक नजर है करना चाहते हैं।
आप प्रोफाइलर का उपयोग करते हैं अपने डेटाबेस के खिलाफ एक मानक काम का बोझ कब्जा करने के लिए, DETA सिफारिश कर सकते हैं कि तुम क्या सांख्यिकी और अनुक्रमित लागू हो सकते हैं।
सावधान रहें कि ट्यूनिंग को विचारों का एक अच्छा सौदा की आवश्यकता है, क्योंकि नई अनुक्रमणिका जोड़ना आपके वर्कलोड की गति को बढ़ा सकता है, लेकिन आप एक बहुत ही महत्वपूर्ण नुकसान के लिए एक महत्वपूर्ण क्वेरी की गति बढ़ा सकते हैं।
वहाँ जिसके बारे में कैसे प्रश्नों काम कुछ बहुत अच्छी सलाह है TSQL क्वैरी के बारे में एक अच्छी किताब और आप उन्हें कैसे ट्यूनिंग है, जो MSSQL विशिष्ट है देख सकते है।
SQL सर्वर में, यदि आपका डेटाबेस स्कीमा एक अधिक सरल है, तो आपको वास्तव में अधिक ट्यून करने की आवश्यकता नहीं है, क्योंकि प्राथमिक कुंजी स्वचालित रूप से क्लस्टर्ड इंडेक्स में परिणाम देती है, और विदेशी कुंजी बाधाओं को एक अद्वितीय अनुक्रमणिका की आवश्यकता होती है। तो आपके जॉइन का ख्याल रखा जाता है, आमतौर पर।
कहाँ मुश्किल हो जाता है है खोजों और फिल्टर के साथ यह है कि आवेदन उपयोग में प्रश्नों। आपको विशेष रूप से इन प्रश्नों को देखना होगा और अतिरिक्त सूचकांक के लिए उम्मीदवारों की पहचान करनी होगी।
एक अन्य विकल्प एसक्यूएल सर्वर ट्यूनिंग सलाहकार है, लेकिन मैं हतोत्साहित यह फायदा नहीं है, क्योंकि यह इतना शोर उत्पन्न करता है। हालांकि, आप सबसे खराब अपमानजनक प्रश्नों को ढूंढने के लिए इसका उपयोग कर सकते हैं।
अपने सबसे खराब प्रदर्शन करने वाले प्रश्नों की पहचान करने के शुरुआती बिंदु के लिए, कृपया मेरा उत्तर here देखें।
सीखना सीखना कुछ ऐसा है जो अभ्यास की आवश्यकता है।आप इसे कुशल हो चाहते हैं, सजल बांध की किताब खरीदने से शुरू SQL Server Query Performance Tuning Distilled
किम्बर्ली ट्रिप (एसक्यूएल देवी) एक विशेषज्ञ है और इस विषय पर & लिखा बहुत सारे कहा:
http://www.sqlskills.com/BLOGS/KIMBERLY/category/Indexes.aspx
केन इंग्लैंड के Microsoft SQL Server 2000 Performance Optimization and Tuning Handbook एक क्लासिक है। (अमेज़ॅन समीक्षाओं का कहना है कि इस पुस्तक का 2005 संस्करण उतना अच्छा नहीं है)
- 1. मैं मिराह कैसे सीख सकता हूं?
- 2. मैं डायरेक्टशो प्रोग्रामिंग कैसे सीख सकता हूं?
- 3. मैं एएसपी.नेट कैसे सीख सकता हूं?
- 4. मैं CSLA.NET फास्ट कैसे सीख सकता हूं?
- 5. मैं एपीएल कहां से सीख सकता हूं?
- 6. मैं SQL सर्वर लॉग आकार कैसे प्रबंधित कर सकता हूं
- 7. मैं ELMAH SQL सर्वर डेटाबेस कैसे बना सकता हूं?
- 8. मैं SQL सर्वर से डेटा कैसे निर्यात कर सकता हूं?
- 9. मैं एक पूर्ण नौसिखिया हूं, मैं नोड कैसे सीख सकता हूं। जेएस + एक्सप्रेस + मोंगोडीबी?
- 10. मैं _really_ निम्न-स्तरीय नेटवर्क प्रोग्रामिंग कैसे सीख सकता हूं?
- 11. मैं रूबी के लिए रेगेक्स कैसे सीख सकता हूं?
- 12. प्रोग्रामिंग प्रतियोगिताओं के लिए मैं एल्गोरिदम कैसे सीख सकता हूं?
- 13. मैं बिल्ड प्रक्रिया को कैसे स्थापित करना सीख सकता हूं?
- 14. मैं सीएडी/सीएएम/सीएनसी प्रोग्रामिंग कैसे सीख सकता हूं?
- 15. मैं सॉफ्टवेयर परीक्षण तकनीक कहां और कैसे सीख सकता हूं?
- 16. मैं SQL सर्वर
- 17. क्या मैं SQL सर्वर 2008 में "कवरिंग, स्पेटियल" इंडेक्स बना सकता हूं?
- 18. मैं SQL सर्वर 2008 में एक आंतरिक तालिका कैसे देख सकता हूं?
- 19. समग्र इंडेक्स बनाम SQL सर्वर में कवरिंग इंडेक्स शामिल करें
- 20. क्या मैं SQL सर्वर से sa लॉगिन हटा सकता हूं?
- 21. क्या मैं SQL सर्वर में वैश्विक फ़ंक्शन बना सकता हूं?
- 22. क्या मैं SQL सर्वर में 0 कॉलम चुन सकता हूं?
- 23. क्या मैं SQL सर्वर एक्सप्रेस के साथ SQL सर्वर स्थापित कर सकता हूं?
- 24. एसक्यूएल सर्वर ट्यूनिंग सलाहकार के लिए वैकल्पिक?
- 25. मैं अपने स्रोत कोड को कैसे इंडेक्स कर सकता हूं?
- 26. इकाई फ्रेमवर्क और एसक्यूएल सर्वर ट्यूनिंग सलाहकार
- 27. मैं .sql फ़ाइल में SQL वाक्यविन्यास कैसे देख सकता हूं?
- 28. पार्सिंग, मैं इसके बारे में कहां से सीख सकता हूं
- 29. जहां मैं ककड़ी को विस्तार से सीख सकता हूं?
- 30. यदि मैं रावेनडीबी चुनता हूं, तो मैं SQL सर्वर का क्या लाभ खो सकता हूं?
जब मैंने इसका उत्तर दिया, तो मैंने पूछा कि क्या मैं इंसान था या बॉट! :(lol – MikeW
जेफ के अमेज़ॅन रेफरल्स चोरी करना बंद करो! यही कारण है कि एसओ आपके बॉट को क्यों सोचता है –