एसक्यूएल के बीच मतभेद विद्यमान हैं और में
एसक्यूएल बनाम बनाम
टीएसक्यूएल में समस्या हल करने के लिए अलग-अलग तरीकों से उपलब्ध है और वांछित परिणाम उनमें से किसी का उपयोग करते हुए देखा जा सकता है। अंतिम परिणाम प्राप्त किए जा सकने वाले तरीकों में से एक IN और EXISTS खंडों के उपयोग के माध्यम से है धाराओं के उपयोग के परिणाम सेट के छानने में मदद करता है एक उपकुंजी के संदर्भ में जो उपलब्ध है। IN और EXISTS का निष्पादन थोड़ा अलग है और यह इन अंतरों का मूल्यांकन किया गया है।
इसमें विभिन्न कारक हैं जो यह तय करते हैं कि या नहीं, या मौजूदा में शुरू हो जाएगा। उनमें से एक तालिका में उपलब्ध डेटा राशि है। एसक्यूएल सर्वर में सूचकांक की एक बड़ी मात्रा में एक सूचकांक खोज का उपयोग करने के बजाय एक सूचकांक स्कैन का उपयोग करने के लिए वापसी में परिणाम।
मतभेद < दिए गए आंकड़े भी निष्पादन योजना के बारे में बहुत कुछ बताते हैं जिनका पालन किया जाना चाहिए। अंतर दिखाया गया है जब सर्वर ने एक वैध निर्णय लेने के लिए पर्याप्त आंकड़े जमा किए हैं और जब कोई आंकड़ा पहली बार नहीं होता है। उपयोग में हार्डवेयर यह भी निर्धारित करता है कि क्या IN या EXISTS नियोजित होंगे। यह सीपीयू की उपलब्ध की संख्या पर काफी हद तक निर्भर है।
इस घटना में कि एक सबक्व्यरी का उपयोग किया जाता है और एक रिक्त मूल्य वापस किया जाता है, पूरे बयान शून्य हो जाता है यह प्रभाव EXISTS कीवर्ड के उपयोग के लिए इंगित करता है। IN कीवर्ड के उपयोग के बारे में आता है जब उपकुंजी में विभिन्न मानों की तुलना की आवश्यकता होती है। EXISTS कीवर्ड को मुख्य रूप से सही या गलत विवरणों के मूल्यांकन में प्रयोग किया जाता है और IN सबसे अधिक प्रासंगिक उपविक्री विवरणों में उपयोग किया जाता है।
-3 ->
सामान्य तौर पर, मौजूदा, INISTS INR से अधिक तेज़ होंगे, इसका कारण यह है कि जब EXISTS चलाए जा रहे हैं, तो खोज को एक हिट मिला है और यह समीक्षा करेगा कि क्या स्थिति सही साबित हुई है या नहीं। IN में चलते समय, यह सबक्यूबरी से सभी परिणाम एकत्र करता है और उन्हें आगे की प्रक्रिया के लिए प्रस्तुत करता है, और इस प्रक्रिया को कुछ समय लगता है।यह ध्यान रखना ज़रूरी है कि प्रश्न का अनुपालन ठीक से किया जाना चाहिए और चलने से पहले जांच की जानी चाहिए। यह सुनिश्चित करने में विफलता है कि क्वेरी सही परिणाम EXISTS और इन्हें विभिन्न मानों को प्रस्तुत करते हुए और एसक्यूएल सर्वर में उनके उपयोग का उद्देश्य नहीं है। अनुकूलनकर्ता हमेशा यथायोग्य होना चाहिए जब यह काम करना चाहिए
सारांश
टीएसक्यूएल में समस्या हल करना आमतौर पर EXISTS और IN के साथ किया जाता है।
EXISTS और IN को चालू करते समय थोड़ा अंतर देखा जाता है, हालांकि प्रत्येक के लिए अनुकूलन समान मूल्य देना चाहिए।
आंकड़ों के निर्धारण में से एक यह है कि क्या मौजूदा या IN को चालू किया जाएगा
उपयोग में हार्डवेयर भी निर्धारित करने में महत्वपूर्ण है कि क्या मौजूदा या IN को तैनात किया जाना है
EXISTS का चलना उपयोगी होगा जब वहाँ किसी अन्य क्वेरी के परिणामों को एक और subquery के साथ सहसंबंधित करने की आवश्यकता हैमौजूदा या गलत बयानों को मूल्यांकन की आवश्यकता होती है, इसलिए EXISTS भी बहुत आम है
आम तौर पर तब इस्तेमाल किया जाता है जब किसी सूची में विशिष्ट कॉलम प्राप्त करने की आवश्यकता होती है। इसके अलावा यह आमतौर पर प्रयोग किया जाता है जब उपकुरीयतों में मूल्य तुलना की आवश्यकता होती है।
EXISTS आम तौर से IN के मुकाबले तेज़ है, जैसा कि यह चलता है, एक हिट मिल जाता है, और समीक्षा करता है कि क्या स्थिति सही साबित हुई है
IN धीमी है क्योंकि यह सबक्यूबरी से सभी परिणाम एकत्र करता है और इसे संसाधित करता है
हालांकि विभिन्न फांसी मौजूद हैं, अनुकूलन को भी EXISTS और IN में समान परिणाम देना चाहिए।