एक डेटाबेस की रूपरेखा बनाते समय मैं एक ऐसे दृश्य के बारे में आया जो कुछ गैर-नियतात्मक कार्यों को संदर्भित कर रहा है, जो इस एप्लिकेशन के पूल में प्रत्येक कनेक्शन के लिए प्रति मिनट 1000-2500 बार एक्सेस किया जाता है। SELECT
दृश्य से एक साधारण निम्नलिखित निष्पादन योजना प्राप्त करता है:
यह उस दृश्य के लिए एक जटिल योजना की तरह लगता है जिसमें हजार पंक्तियों से कम है जो हर कुछ महीनों में एक पंक्ति या दो परिवर्तन देख सकते हैं। लेकिन यह निम्नलिखित अन्य टिप्पणियों के साथ खराब हो जाता है:
- नेस्टेड विचार गैर-निर्धारक हैं, इसलिए हम उन्हें अनुक्रमित नहीं कर सकते हैं
- प्रत्येक दृश्य
UDF
स्ट्रिंग्स के निर्माण के लिए कई एस का संदर्भ देता है - प्रत्येक UDF में
UDF
स्थानीय भाषाओं के लिए ISO कोड प्राप्त करने के लिए नेस्टेड s होते हैं - स्टैक में देखे जाने वाले अतिरिक्त स्ट्रिंग बिल्डरों का उपयोग कर रहे हैं जो कि पेडिकेट्स के रूप में एस से लौटे हैं
UDF
JOIN
- प्रत्येक दृश्य स्टैक को एक तालिका के रूप में माना जाता है, जिसका अर्थ है कि अंतर्निहित तालिकाओं को लिखने के लिए प्रत्येक पर
INSERT
/UPDATE
/DELETE
ट्रिगर हैं - ये ट्रिगर उन विचारों पर संग्रहीत संग्रहीत प्रक्रियाओं का उपयोग
CURSORS
करते हैंEXEC
जो इन स्ट्रिंग बिल्डिंगUDF
s का अधिक संदर्भ देते हैं ।
यह मेरे लिए बहुत सड़ा हुआ लगता है, लेकिन मुझे केवल TSQL के साथ कुछ वर्षों का अनुभव है। यह भी बेहतर हो जाता है!
ऐसा प्रतीत होता है कि डेवलपर ने फैसला किया कि यह एक महान विचार था, यह सब इसलिए किया ताकि जमा किए गए कुछ सौ तार एक UDF
स्कीमा-विशिष्ट से लौटे स्ट्रिंग पर आधारित अनुवाद हो सकें ।
यहाँ ढेर में से एक दृश्य है, लेकिन वे सभी समान रूप से खराब हैं:
CREATE VIEW [UserWKStringI18N]
AS
SELECT b.WKType, b.WKIndex
, CASE
WHEN ISNULL(il.I18NID, N'') = N''
THEN id.I18NString
ELSE il.I18nString
END AS WKString
,CASE
WHEN ISNULL(il.I18NID, N'') = N''
THEN id.IETFLangCode
ELSE il.IETFLangCode
END AS IETFLangCode
,dbo.User3StringI18N_KeyValue(b.WKType, b.WKIndex, N'WKS') AS I18NID
,dbo.UserI18N_Session_Locale_Key() AS IETFSessionLangCode
,dbo.UserI18N_Database_Locale_Key() AS IETFDatabaseLangCode
FROM UserWKStringBASE b
LEFT OUTER JOIN User3StringI18N il
ON (
il.I18NID = dbo.User3StringI18N_KeyValue(b.WKType, b.WKIndex, N'WKS')
AND il.IETFLangCode = dbo.UserI18N_Session_Locale_Key()
)
LEFT OUTER JOIN User3StringI18N id
ON (
id.I18NID = dbo.User3StringI18N_KeyValue(b.WKType, b.WKIndex,N'WKS')
AND id.IETFLangCode = dbo.UserI18N_Database_Locale_Key()
)
GO
यहाँ क्यों UDF
s JOIN
विधेय के रूप में इस्तेमाल किया जा रहा है। I18NID
स्तंभ श्रृंखलाबद्ध द्वारा बनाई है:STRING + [ + ID + | + ID + ]
इनका परीक्षण करने के दौरान, SELECT
दृश्य से एक सरल ~ 309 पंक्तियों की वापसी होती है, और निष्पादित करने के लिए 900-1400ms लगते हैं। यदि मैं स्ट्रिंग्स को किसी अन्य तालिका में डंप करता हूं और उस पर एक इंडेक्स को थप्पड़ मारता है, तो वही चयन 20-75ms में रिटर्न करता है।
इसलिए, लंबी कहानी छोटी (और मुझे उम्मीद है कि आपने इस मूर्खता की कुछ सराहना की) मैं एक अच्छा सामरी होना चाहता हूं और इस उत्पाद को चलाने वाले 99% ग्राहकों के लिए फिर से लिखना चाहता हूं, जो किसी भी स्थानीयकरण का उपयोग नहीं करते हैं- -उपयोगकर्ताओं से अपेक्षा की जाती है [en-US]
कि जब अंग्रेजी दूसरी / तीसरी भाषा हो तब भी लोकेल का उपयोग करें ।
चूंकि यह एक अनौपचारिक हैक है, मैं निम्नलिखित के बारे में सोच रहा हूं:
- मूल आधार तालिकाओं से डेटा के साफ-सुथरे रूप से जोड़े गए एक नई स्ट्रिंग तालिका बनाएं
- तालिका को अनुक्रमित करें।
- ढेर में शीर्ष स्तर के दृश्य शामिल हैं इस बात का एक प्रतिस्थापन समूह बनाना होगा
NVARCHAR
औरINT
के लिए कॉलमWKType
औरWKIndex
कॉलम। UDF
इनमें से एक मुट्ठी को संशोधित करें जो इन विचारों को संदर्भ में शामिल होने से बचने के लिए कुछ सम्मिलित विधेयकों में जोड़ता है (हमारी सबसे बड़ी ऑडिट टेबल 500-2,000M पंक्तियाँ हैं औरINT
एकNVARCHAR(4000)
स्तंभ में संग्रहीत करता है जो स्तंभ के खिलाफ शामिल होने के लिए उपयोग किया जाता है )WKIndex
(INT
)।- योजनाओं पर विचार करें
- विचारों में कुछ अनुक्रमणिकाएँ जोड़ें
- कर्सर के बजाय सेट लॉजिक का उपयोग करके विचारों पर ट्रिगर का पुनर्निर्माण करें
अब, मेरे वास्तविक प्रश्न:
- क्या एक दृश्य के माध्यम से स्थानीयकृत तार को संभालने के लिए एक सर्वोत्तम अभ्यास विधि है?
UDF
स्टब के रूप में उपयोग के लिए कौन से विकल्प मौजूद हैं ? (मैंVIEW
प्रत्येक स्कीमा मालिक के लिए एक विशिष्ट लिख सकता हूं और विभिन्न प्रकार केUDF
स्टब्स पर निर्भर होने के बजाय भाषा को हार्ड-कोड कर सकता हूं )- क्या इन दृश्यों को पूरी तरह से नेस्टेड
UDF
एस को पूरी तरह से निर्धारित करके और फिर स्टैक को नजरअंदाज करके निर्धारक बनाया जा सकता है ?
UDF
परिभाषा भी पोस्ट करें । इसके अलावा, T-SQL यूज़र-डिफ़ाइंड फ़ंक्शंस का