Sqlserver
 sql >> डेटाबेस >  >> RDS >> Sqlserver

एसएसआईएस में चर को कैसे संशोधित करें?

जैसा कि @Yuck और @devarc ने नोट किया है, दो अलग और अलग मान हैं एक चर धारण करता है। डिज़ाइन-टाइम मान वह मान है जिसे आप पहली बार वैरिएबल बनाते समय असाइन करते हैं। आपके मामले में, वेरिएबल C:\Test.txt को डिज़ाइन-टाइम मान के रूप में रखता है। हर बार जब आप पैकेज खोलते हैं, तो यह C:\Test.txt दिखाएगा जब तक कि आप इसे

. में नहीं बदलते

पैकेज के चलने के दौरान परिवर्तनशील परिवर्तन का मान बनाने के लिए, आपके विकल्प या तो मान सेट करने या इसकी गणना करने के लिए हैं। यहां मैंने एक पैकेज-स्तरीय वैरिएबल CurrentFile created बनाया है C:\Test.txt

. के मान के साथ

एक बात जो अक्सर लोगों को परेशान करती है, वह यह है कि उन्होंने रन-टाइम मान को सही ढंग से बदल दिया है, लेकिन जब वे इसे BIDS में चलाते हैं, तो उन्हें "पुराना" मान दिखाई देता है। वैरिएबल विंडो में प्रदर्शित मान पैकेज निष्पादन के दौरान नहीं बदलता है।

पैकेज निष्पादन के दौरान, मेरी वेरिएबल विंडो अभी भी डिज़ाइन-टाइम मान (C:\Test.txt) दिखाती है, लेकिन वास्तविक मान स्थानीय विंडो (C:\Test2.txt)

में दिखाई देता है।

मान सेट करना

SSIS में किसी भी चीज़ का मूल्य वर्बोज़ कमांड-लाइन विकल्प या कॉन्फ़िगरेशन के ज़रिए स्रोत। मेरे दिमाग में सबसे बड़ा अंतर यह है कि यह दृष्टिकोण यह है कि मूल्य हमेशा पैकेज निष्पादन के पूरे जीवनकाल के लिए मूल्य होगा। किसी पैकेज के अनुक्रमिक या समानांतर आमंत्रण उस मान को बदल सकते हैं लेकिन उस . के लिए निष्पादन मूल्य स्थिर रहेगा (मान के स्पष्ट संशोधन को छोड़कर।

/सेट

कमांड-लाइन निष्पादन (dtexec.exe), पैकेज पर राइट क्लिक करना और फाइल सिस्टम (dtexecUI.exe) से चलना या SQL सर्वर इंटीग्रेशन सर्विसेज का SQL एजेंट जॉब स्टेप बनाना, सभी SET कमांड के माध्यम से रन-टाइम मान प्रदान करने की अनुमति देते हैं। . उपरोक्त चर का उपयोग करते हुए, निम्न आदेश रन-टाइम मान को C:\Test2.txt पर सेट करेगा

dtexec /file C:\Generated.dtsx /set \Package.Variables[User::CurrentFile].Properties[Value];"C:\Test2.txt"

कॉन्फ़िगरेशन

SSIS पैकेजों को रन-टाइम मान प्रदान करने के लिए कॉन्फ़िगरेशन स्रोत बनाने का विकल्प प्रदान करता है। ऊपर जो लेख मैंने लिंक किया है, वह कॉन्फ़िगरेशन विकल्पों के पेशेवरों और विपक्षों का वर्णन करने से कहीं बेहतर काम करता है, जो मैं यहां करूंगा। मैं कहूंगा कि मैं आम तौर पर दोनों का उपयोग करता हूं - मेरा एसईटी कमांड एक कनेक्शन प्रबंधक को कॉन्फ़िगर करता है जिसे पैकेज द्वारा पैकेज कॉन्फ़िगरेशन के "पूर्ण" सेट को खोजने के लिए उपयोग किया जाता है।

मान की गणना करना

एसएसआईएस में कई प्रकार के कार्य हैं जो एक चर के मूल्य के साथ-साथ एक मूल्य को बदलने के लिए अभिव्यक्तियों के उपयोग को भी बदल सकते हैं। मैं इन्हें ऐसी चीजों के रूप में देखता हूं जो पैकेज के उड़ान में होने पर मूल्य पर काम करती हैं।

कार्य

एक स्क्रिप्ट कार्य शुरू करने वालों के लिए सबसे अधिक उपयोग किए जाने वाले तंत्रों में से एक है, लेकिन मुझे एसएसआईएस टूलकिट में अन्य टूल्स मिलते हैं जो आमतौर पर परिवर्तनीय मानों को बदलने के लिए उपयुक्त होते हैं।

फॉरच लूप कंटेनर और SQL कार्य निष्पादित करें दो अन्य बड़े कार्य हैं जिन्हें आपको एक चर मान के असाइनमेंट के लिए देखना चाहिए।

अभिव्यक्ति

एसएसआईएस टूलबॉक्स में एक्सप्रेशन सबसे शानदार कैंडी हैं। एसएसआईएस में अधिकांश "चीज" कॉन्फ़िगरेशन के लिए गुणों को उजागर करती है। यह मददगार है, लेकिन उन गुणों को बनाने के लिए एक्सप्रेशन असाइन करने का उपयोग करना बकाया है।

उदाहरण के लिए, 3 चरों की कल्पना करें RootFolder , FileName और ComputedCurrentFile C:\, File2.txt और खाली स्ट्रिंग के मानों के साथ। ComputedCurrentFile . के लिए प्रॉपर्टी विंडो पर हम EvaluateAsExpression के मान को False से True में बदल देंगे और फिर @[User::RootFolder]+ "\\" [email protected][User::FileName] यह केवल पहले दो चर के मूल्य को एक साथ जोड़ता है। यह मददगार हो सकता है यदि प्रसंस्करण के लिए फ़ाइल का नाम मानक था लेकिन स्रोत फ़ोल्डर अक्सर बदल जाता था। या यदि हम आउटपुट के बारे में बात कर रहे हैं, तो दिनांक और संभवतः पैकेज के चलने के समय का उपयोग करके आउटपुट फ़ाइल नाम बनाने के लिए एक्सप्रेशन का उपयोग करना आम बात है।

अंत में, ऐसा कुछ भी नहीं है जो इन दृष्टिकोणों के मिश्रण और मिलान को रोकता है। मैं आम तौर पर सही प्रारंभिक फ़ोल्डर में फ़ाइल एन्यूमरेटर को इंगित करने के लिए कॉन्फ़िगरेशन का उपयोग करता हूं और फिर प्रसंस्करण के लिए वर्तमान फ़ाइल की पहचान करने के लिए परिकलित मानों का उपयोग करता हूं।



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. माइक्रोसॉफ्ट द्वारा डाटाबेस नेमिंग कन्वेंशन?

  2. एसक्यूएल में जाने के साथ गतिशील क्वेरी निष्पादित करें

  3. एक स्ट्रिंग में पहला गैर-संख्यात्मक वर्ण खोजने के लिए SQL

  4. माइक्रोसॉफ्ट एसक्यूएल सर्वर 2008 में एक क्वेरी चलाने से पहले कैसे पता चलेगा कि कितनी पंक्तियां प्रभावित होंगी?

  5. टी-एसक्यूएल में पिछले महीनों के डेटा के आधार पर गुम महीनों के मूल्यों का निर्धारण कैसे करें