Teradata - त्वरित गाइड

तेरदता क्या है?

Teradata लोकप्रिय रिलेशनल डेटाबेस मैनेजमेंट सिस्टम में से एक है। यह मुख्य रूप से बड़े पैमाने पर डेटा वेयरहाउसिंग अनुप्रयोगों के निर्माण के लिए उपयुक्त है। तेरदता इसे समानता की अवधारणा से प्राप्त करती है। यह टेराडाटा नामक कंपनी द्वारा विकसित किया गया है।

तेरदता का इतिहास

टेराडाटा के इतिहास का एक त्वरित सारांश निम्नलिखित है, प्रमुख मील के पत्थर की सूची।

  • 1979 - तेरदता को शामिल किया गया।

  • 1984 - पहले डेटाबेस कंप्यूटर डीबीसी / 1012 का विमोचन।

  • 1986- फॉर्च्यून पत्रिका ने टेराडाटा को 'वर्ष का उत्पाद' नाम दिया है।

  • 1999 - 130 टेराबाइट्स के साथ टेराडाटा का उपयोग कर दुनिया में सबसे बड़ा डेटाबेस।

  • 2002 - Teradata V2R5 विभाजन प्राथमिक सूचकांक और संपीड़न के साथ जारी किया गया।

  • 2006 - तारादत्त मास्टर डाटा प्रबंधन समाधान का शुभारंभ।

  • 2008 - टेराडाटा 13.0 सक्रिय डेटा वेयरहाउसिंग के साथ जारी किया गया।

  • 2011 - Teradata Aster को एक्वायर्ड करता है और एडवांस्ड एनालिटिक्स स्पेस में प्रवेश करता है।

  • 2012 - टेराडाटा 14.0 पेश किया।

  • 2014 - टेराडाटा 15.0 पेश किया।

टेराडाटा की विशेषताएं

तेरदता की कुछ विशेषताएं निम्नलिखित हैं -

  • Unlimited Parallelism- Teradata डेटाबेस सिस्टम बड़े पैमाने पर समानांतर प्रसंस्करण (MPP) आर्किटेक्चर पर आधारित है। MPP आर्किटेक्चर पूरे सिस्टम में समान रूप से वर्कलोड को विभाजित करता है। Teradata प्रणाली अपनी प्रक्रियाओं के बीच कार्य को विभाजित करती है और उन्हें समानांतर में चलाता है ताकि यह सुनिश्चित हो सके कि कार्य जल्दी से पूरा हो गया है।

  • Shared Nothing Architecture- टेराडाटा की वास्तुकला को साझा कुछ भी नहीं वास्तुकला कहा जाता है। टेराडाटा नोड्स, इसके एक्सेस मॉड्यूल प्रोसेसर्स (एएमपी) और एएमपी से जुड़े डिस्क स्वतंत्र रूप से काम करते हैं। उन्हें दूसरों के साथ साझा नहीं किया जाता है।

  • Linear Scalability- Teradata सिस्टम अत्यधिक स्केलेबल हैं। वे 2048 नोड्स तक स्केल कर सकते हैं। उदाहरण के लिए, आप एएमपी की संख्या को दोगुना करके सिस्टम की क्षमता को दोगुना कर सकते हैं।

  • Connectivity - टेराडाटा चैनल से जुड़ी प्रणालियों जैसे मेनफ्रेम या नेटवर्क से जुड़े सिस्टम से जुड़ सकता है।

  • Mature Optimizer- टेराडाटा ऑप्टिमाइज़र बाजार में परिपक्व ऑप्टिमाइज़र में से एक है। इसकी शुरुआत से ही समानांतर होने के लिए डिज़ाइन किया गया है। यह प्रत्येक रिलीज के लिए परिष्कृत किया गया है।

  • SQL- टेराडाटा तालिकाओं में संग्रहीत डेटा के साथ बातचीत करने के लिए उद्योग मानक एसक्यूएल का समर्थन करता है। इसके अतिरिक्त, यह अपना स्वयं का विस्तार प्रदान करता है।

  • Robust Utilities - Teradata, FastLoad, MultiLoad, FastExport और TPT जैसे Teradata सिस्टम से / से डेटा आयात / निर्यात करने के लिए मजबूत उपयोगिताओं प्रदान करता है।

  • Automatic Distribution - Teradata स्वचालित रूप से किसी भी मैनुअल हस्तक्षेप के बिना डिस्क के लिए समान रूप से डेटा वितरित करता है।

टेराडाटा वीएमवेयर के लिए टेराडाटा एक्सप्रेस प्रदान करता है जो पूरी तरह से ऑपरेशनल टेराडाटा वर्चुअल मशीन है। यह 1 टेराबाइट तक स्टोरेज प्रदान करता है। Teradata VMware के 40GB और 1TB संस्करण दोनों प्रदान करता है।

आवश्यक शर्तें

चूंकि VM 64 बिट है, इसलिए आपके CPU को 64-बिट का समर्थन करना चाहिए।

विंडोज के लिए इंस्टालेशन स्टेप्स

Step 1 - लिंक से आवश्यक वीएम संस्करण डाउनलोड करें, https://downloads.teradata.com/download/database/teradata-express-for-vmware-player

Step 2 - फ़ाइल निकालें और लक्ष्य फ़ोल्डर निर्दिष्ट करें।

Step 3 - लिंक से VMWare वर्कस्टेशन प्लेयर डाउनलोड करें, https://my.vmware.com/web/vmware/downloads। यह विंडोज और लिनक्स दोनों के लिए उपलब्ध है। Windows के लिए VMWARE वर्कस्टेशन प्लेयर डाउनलोड करें।

Step 4 - डाउनलोड पूरा होने के बाद, सॉफ्टवेयर इंस्टॉल करें।

Step 5 - इंस्टॉलेशन पूरा होने के बाद, VMWARE क्लाइंट को रन करें।

Step 6- 'एक आभासी मशीन खोलें' का चयन करें। निकाले गए Teradata VMWare फ़ोल्डर के माध्यम से नेविगेट करें और एक्सटेंशन .vmdk के साथ फ़ाइल का चयन करें।

Step 7- Teradata VMWare को VMWare क्लाइंट में जोड़ा जाता है। जोड़े गए Teradata VMware का चयन करें और 'वर्चुअल मशीन चलाएं' पर क्लिक करें।

Step 8 - यदि आपको सॉफ़्टवेयर अपडेट पर पॉपअप मिलता है, तो आप 'रिमाइंड मी लेटर' का चयन कर सकते हैं।

Step 9 - यूजर नेम को रूट के रूप में दर्ज करें, टैब दबाएं और पासवर्ड को रूट के रूप में दर्ज करें और फिर से एंटर दबाएं।

Step 10- डेस्कटॉप पर निम्न स्क्रीन दिखाई देने पर, 'रूट के होम' पर डबल-क्लिक करें। फिर 'जीनोम टर्मिनल' पर डबल-क्लिक करें। इससे शेल खुल जाएगा।

Step 11- निम्न शेल से, कमांड /etc/init.d/tpa प्रारंभ दर्ज करें। यह Teradata सर्वर को शुरू करेगा।

BTEQ को शुरू करना

BTEQ उपयोगिता का उपयोग SQL प्रश्नों को अंतःक्रियात्मक रूप से प्रस्तुत करने के लिए किया जाता है। निम्नलिखित BTEQ उपयोगिता शुरू करने के लिए कदम हैं।

Step 1 - कमांड / sbin / ifconfig दर्ज करें और VMWare के आईपी पते को नोट करें।

Step 2- कमांड bteq चलाएँ। लॉगऑन प्रॉम्प्ट पर, कमांड दर्ज करें।

लोगन <ipaddress> / dbc, dbc; और पासवर्ड प्रॉम्प्ट पर दर्ज करें, dbc के रूप में पासवर्ड दर्ज करें;

आप BTEQ का उपयोग करके Teradata सिस्टम में लॉग इन कर सकते हैं और किसी भी SQL क्वेरी को चला सकते हैं।

Teradata वास्तुकला बड़े पैमाने पर समानांतर प्रसंस्करण (MPP) वास्तुकला पर आधारित है। Teradata के प्रमुख घटक पार्सिंग इंजन, BYNET और एक्सेस मॉड्यूल प्रोसेसर (AMPs) हैं। निम्न आरेख एक टेराडाटा नोड के उच्च स्तर के वास्तुकला को दर्शाता है।

तेरदता के घटक

Teradata के प्रमुख घटक इस प्रकार हैं -

  • Node- यह टेराडाटा सिस्टम में मूल इकाई है। एक Teradata प्रणाली में प्रत्येक व्यक्तिगत सर्वर एक नोड के रूप में जाना जाता है। एक नोड में अपना स्वयं का ऑपरेटिंग सिस्टम, सीपीयू, मेमोरी, Teradata RDBMS सॉफ्टवेयर और डिस्क स्थान की अपनी प्रति शामिल होती है। एक कैबिनेट में एक या अधिक नोड होते हैं।

  • Parsing Engine- पार्सिंग इंजन क्लाइंट से प्रश्न प्राप्त करने और एक कुशल निष्पादन योजना तैयार करने के लिए जिम्मेदार है। पार्सिंग इंजन की जिम्मेदारियां हैं -

    • क्लाइंट से SQL क्वेरी प्राप्त करें

    • वाक्यविन्यास त्रुटियों के लिए SQL क्वेरी चेक को पार्स करें

    • जांचें कि क्या उपयोगकर्ता को SQL क्वेरी में उपयोग की गई वस्तुओं के खिलाफ विशेषाधिकार की आवश्यकता है

    • जाँच करें कि क्या SQL में उपयोग की गई वस्तुएँ वास्तव में मौजूद हैं

    • SQL क्वेरी को निष्पादित करने के लिए निष्पादन योजना तैयार करें और इसे BYNET को पास करें

    • एएमपी से परिणाम प्राप्त करता है और ग्राहक को भेजता है

  • Message Passing Layer- मैसेज पासिंग लेयर जिसे BYNET कहा जाता है, टेराडाटा सिस्टम में नेटवर्किंग लेयर है। यह पीई और एएमपी के बीच और नोड्स के बीच संचार की अनुमति देता है। यह पर्सिंग इंजन से निष्पादन योजना प्राप्त करता है और एएमपी को भेजता है। इसी तरह, यह एएमपी से परिणाम प्राप्त करता है और पार्सिंग इंजन को भेजता है।

  • Access Module Processor (AMP)- एएमपी, जिसे वर्चुअल प्रोसेसर कहा जाता है (vprocs) वे हैं जो वास्तव में डेटा को संग्रहीत और पुनर्प्राप्त करते हैं। एएमपी पार्सिंग इंजन से डेटा और निष्पादन योजना प्राप्त करते हैं, किसी भी डेटा प्रकार के रूपांतरण, एकत्रीकरण, फिल्टर, छंटनी करते हैं और उनसे जुड़े डिस्क में डेटा संग्रहीत करते हैं। तालिकाओं से रिकॉर्ड सिस्टम में एएमपी के बीच समान रूप से वितरित किए जाते हैं। प्रत्येक एएमपी डिस्क के एक सेट से जुड़ा होता है जिस पर डेटा संग्रहीत किया जाता है। केवल वह एएमपी डिस्क से डेटा पढ़ / लिख सकता है।

भंडारण वास्तुकला

जब क्लाइंट रिकॉर्ड सम्मिलित करने के लिए क्वेरी चलाता है, तो पार्सिंग इंजन रिकॉर्ड को BYNET को भेजता है। BYNET रिकॉर्ड्स को पुनः प्राप्त करता है और पंक्ति को लक्ष्य AMP पर भेजता है। एएमपी इन रिकॉर्ड्स को अपने डिस्क पर संग्रहीत करता है। निम्नलिखित आरेख टेराडाटा के भंडारण वास्तुकला को दर्शाता है।

पुनर्प्राप्ति वास्तुकला

जब क्लाइंट रिकॉर्ड पुनर्प्राप्त करने के लिए क्वेरी चलाता है, तो पार्सिंग इंजन BYNET को एक अनुरोध भेजता है। BYNET उपयुक्त AMP को पुनर्प्राप्ति अनुरोध भेजता है। तब एएमपी समानांतर में अपने डिस्क को खोजते हैं और आवश्यक रिकॉर्ड और BYNET को भेजते हैं। BYNET तब पार्सिंग इंजन को रिकॉर्ड भेजता है जो बदले में ग्राहक को भेजेगा। निम्नलिखित टेराडाटा की पुनर्प्राप्ति वास्तुकला है।

रिलेशनल डेटाबेस मैनेजमेंट सिस्टम (RDBMS) एक डीबीएमएस सॉफ्टवेयर है जो डेटाबेस के साथ इंटरैक्ट करने में मदद करता है। वे तालिकाओं में संग्रहीत डेटा के साथ बातचीत करने के लिए संरचित क्वेरी भाषा (एसक्यूएल) का उपयोग करते हैं।

डेटाबेस

डेटाबेस तार्किक रूप से संबंधित डेटा का एक संग्रह है। वे विभिन्न प्रयोजनों के लिए कई उपयोगकर्ताओं द्वारा एक्सेस किए जाते हैं। उदाहरण के लिए, एक बिक्री डेटाबेस में बिक्री के बारे में पूरी जानकारी होती है जो कई तालिकाओं में संग्रहीत होती है।

टेबल

RDBMS में टेबल्स एक मूल इकाई होती है जहाँ डेटा संग्रहीत किया जाता है। एक तालिका पंक्तियों और स्तंभों का एक संग्रह है। निम्नलिखित कर्मचारी तालिका का एक उदाहरण है।

कर्मचारी संख्या पहला नाम उपनाम जन्म दिन
101 माइक जेम्स 1980/01/05
104 एलेक्स स्टुअर्ट 1984/11/06
102 रॉबर्ट विलियम्स 1983/03/05
105 रॉबर्ट जेम्स 1984/12/01
103 पीटर पॉल 1983/04/01

कॉलम

एक कॉलम में समान डेटा होता है। उदाहरण के लिए, कर्मचारी तालिका में कॉलम जन्म तिथि में सभी कर्मचारियों के लिए जन्मतिथि की जानकारी है।

जन्म दिन
1980/01/05
1984/11/06
1983/03/05
1984/12/01
1983/04/01

पंक्ति

पंक्ति सभी स्तंभों में से एक उदाहरण है। उदाहरण के लिए, कर्मचारी तालिका में एक पंक्ति में एकल कर्मचारी के बारे में जानकारी होती है।

कर्मचारी संख्या पहला नाम उपनाम जन्म दिन
101 माइक जेम्स 1980/01/05

प्राथमिक कुंजी

प्राथमिक कुंजी का उपयोग तालिका में पंक्ति को विशिष्ट रूप से पहचानने के लिए किया जाता है। प्राथमिक कुंजी कॉलम में कोई डुप्लिकेट मान की अनुमति नहीं है और वे NULL मान स्वीकार नहीं कर सकते। यह एक तालिका में एक अनिवार्य क्षेत्र है।

विदेशी कुंजी

तालिकाओं के बीच संबंध बनाने के लिए विदेशी कुंजियों का उपयोग किया जाता है। बाल तालिका में एक विदेशी कुंजी को मूल तालिका में प्राथमिक कुंजी के रूप में परिभाषित किया गया है। एक तालिका में एक से अधिक विदेशी कुंजी हो सकती हैं। यह डुप्लिकेट मानों और शून्य मानों को भी स्वीकार कर सकता है। विदेशी कुंजियाँ एक तालिका में वैकल्पिक हैं।

तालिका में प्रत्येक स्तंभ डेटा प्रकार से संबद्ध है। डेटा प्रकार निर्दिष्ट करते हैं कि किस प्रकार के मान कॉलम में संग्रहीत किए जाएंगे। Teradata कई डेटा प्रकारों का समर्थन करता है। निम्नलिखित अक्सर उपयोग किए जाने वाले डेटा प्रकारों में से कुछ हैं।

जानकारी का प्रकार लंबाई (बाइट्स) मूल्यों की श्रृंखला
BYTEINT 1 -128 से +127
SMALLINT 2 -32768 से +32767
पूर्णांक 4 -2,147,483,648 से +2147,483,647
BIGINT 8 -9,233,372,036,854,775,80 8 से +9,233,372,036,854,775,8 07
दशमलव 1-16  
संख्यात्मक 1-16  
फ्लोट 8 IEEE प्रारूप
CHAR निश्चित प्रारूप 1-64,000
VARCHAR परिवर्तनशील 1-64,000
दिनांक 4 YYYYYMMDD
समय ६ या 8 HHMMSS.nnnnnn or HHMMSS.nnnnnn + HHMM
TIMESTAMP 10 या 12 YYMMDDHHMMSS.nnnnnn or YYMMDDHHMMSS.nnnnnn + HHMM

रिलेशनल मॉडल में टेबल्स को डेटा के संग्रह के रूप में परिभाषित किया गया है। उन्हें पंक्तियों और स्तंभों के रूप में दर्शाया जाता है।

तालिका प्रकार

प्रकार टेराडाटा विभिन्न प्रकार की तालिकाओं का समर्थन करता है।

  • Permanent Table - यह डिफ़ॉल्ट तालिका है और इसमें उपयोगकर्ता द्वारा डाला गया डेटा होता है और डेटा को स्थायी रूप से संग्रहीत करता है।

  • Volatile Table- एक अस्थिर तालिका में डाला गया डेटा केवल उपयोगकर्ता सत्र के दौरान ही रखा जाता है। सत्र के अंत में तालिका और डेटा को गिरा दिया जाता है। इन तालिकाओं का उपयोग मुख्य रूप से डेटा परिवर्तन के दौरान मध्यवर्ती डेटा को रखने के लिए किया जाता है।

  • Global Temporary Table - ग्लोबल टेम्परेरी टेबल की परिभाषा लगातार बनी रहती है, लेकिन उपयोगकर्ता सत्र के अंत में तालिका में डेटा हटा दिया जाता है।

  • Derived Table- व्युत्पन्न तालिका एक क्वेरी में मध्यवर्ती परिणाम रखती है। उनका जीवनकाल उस क्वेरी के भीतर है जिसमें उन्हें बनाया, उपयोग और गिराया गया है।

बनाम मल्टीसेट सेट करें

टेराडाटा तालिका को SET या MULTISET तालिकाओं के आधार पर वर्गीकृत करता है कि डुप्लिकेट रिकॉर्ड कैसे संभाले जाते हैं। सेट तालिका के रूप में परिभाषित की गई तालिका डुप्लिकेट रिकॉर्ड को संग्रहीत नहीं करती है, जबकि MULTISET तालिका डुप्लिकेट रिकॉर्ड संग्रहीत कर सकती है।

अनु क्रमांक टेबल कमांड और विवरण
1 तालिका बनाएं

टेराबेट में टेबल्स बनाने के लिए क्रिएट टेबल कमांड का उपयोग किया जाता है।

2 तालिका में परिवर्तन

मौजूदा टेबल से कॉलम जोड़ने या छोड़ने के लिए ALTER TABLE कमांड का उपयोग किया जाता है।

3 ड्रॉप तालिका

ड्रॉप टेबल को ड्रॉप करने के लिए DROP TABLE कमांड का उपयोग किया जाता है।

यह अध्याय Teradata तालिकाओं में संग्रहीत डेटा में हेरफेर करने के लिए उपयोग किए जाने वाले SQL कमांड का परिचय देता है।

रिकॉर्ड डालें

INSERT INTO स्टेटमेंट का उपयोग टेबल में रिकॉर्ड डालने के लिए किया जाता है।

वाक्य - विन्यास

निम्नलिखित INSERT INTO के लिए सामान्य वाक्यविन्यास है।

INSERT INTO <tablename> 
(column1, column2, column3,…) 
VALUES 
(value1, value2, value3 …);

उदाहरण

निम्न उदाहरण कर्मचारी तालिका में रिकॉर्ड सम्मिलित करता है।

INSERT INTO Employee (
   EmployeeNo, 
   FirstName, 
   LastName, 
   BirthDate, 
   JoinedDate, 
   DepartmentNo 
)
VALUES ( 
   101, 
   'Mike', 
   'James', 
   '1980-01-05', 
   '2005-03-27', 
   01
);

एक बार उपरोक्त क्वेरी डालने के बाद, आप तालिका से रिकॉर्ड देखने के लिए SELECT स्टेटमेंट का उपयोग कर सकते हैं।

कर्मचारी संख्या पहला नाम उपनाम JoinedDate DepartmentNo जन्म दिन
101 माइक जेम्स 2005/03/27 1 1980/01/05

दूसरी तालिका से डालें

अन्य तालिका से रिकॉर्ड सम्मिलित करने के लिए INSERT SELECT स्टेटमेंट का उपयोग किया जाता है।

वाक्य - विन्यास

निम्नलिखित INSERT INTO के लिए सामान्य वाक्यविन्यास है।

INSERT INTO <tablename> 
(column1, column2, column3,…) 
SELECT 
column1, column2, column3… 
FROM  
<source table>;

उदाहरण

निम्न उदाहरण कर्मचारी तालिका में रिकॉर्ड सम्मिलित करता है। निम्न प्रविष्टि क्वेरी को चलाने से पहले कर्मचारी तालिका के समान कर्मचारी परिभाषा के साथ Employee_Bkup नामक एक तालिका बनाएँ।

INSERT INTO Employee_Bkup ( 
   EmployeeNo, 
   FirstName, 
   LastName, 
   BirthDate, 
   JoinedDate, 
   DepartmentNo 
) 
SELECT 
   EmployeeNo, 
   FirstName, 
   LastName, 
   BirthDate, 
   JoinedDate,
   DepartmentNo 
FROM  
   Employee;

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह कर्मचारी तालिका से कर्मचारी_बेकअप तालिका में सभी रिकॉर्ड सम्मिलित करेगा।

नियमों

  • VALUES सूची में निर्दिष्ट स्तंभों की संख्या INSERT INTO खंड में निर्दिष्ट स्तंभों के साथ मेल खाना चाहिए।

  • मान नॉट कॉलम के लिए अनिवार्य हैं।

  • यदि कोई मान निर्दिष्ट नहीं है, तो Null को अशक्त क्षेत्रों के लिए डाला जाता है।

  • VALUES खंड में निर्दिष्ट डेटा प्रकार INSERT खंड में स्तंभों के डेटा प्रकारों के साथ संगत होना चाहिए।

रिकॉर्ड अपडेट करें

अद्यतन विवरण का उपयोग तालिका से रिकॉर्ड अपडेट करने के लिए किया जाता है।

वाक्य - विन्यास

निम्नलिखित अद्यतन के लिए सामान्य वाक्यविन्यास है।

UPDATE <tablename> 
SET <columnnamme> = <new value> 
[WHERE condition];

उदाहरण

निम्न उदाहरण कर्मचारी 101 के लिए कर्मचारी विभाग के 03 को अद्यतन करता है।

UPDATE Employee 
SET DepartmentNo = 03 
WHERE EmployeeNo = 101;

निम्न आउटपुट में, आप देख सकते हैं कि EmployeeNo 101 के लिए विभागन 1 से 3 तक अपडेट किया गया है।

SELECT Employeeno, DepartmentNo FROM Employee; 
*** Query completed. One row found. 2 columns returned. 
*** Total elapsed time was 1 second.  
EmployeeNo    DepartmentNo 
-----------  ------------- 
   101             3

नियमों

  • आप तालिका के एक या अधिक मानों को अपडेट कर सकते हैं।

  • यदि कोई शर्त निर्दिष्ट नहीं है, तो तालिका की सभी पंक्तियाँ प्रभावित होती हैं।

  • आप किसी तालिका को अन्य तालिका से मानों के साथ अपडेट कर सकते हैं।

रिकॉर्ड हटाएं

DELETE FROM स्टेटमेंट का उपयोग टेबल से रिकॉर्ड अपडेट करने के लिए किया जाता है।

वाक्य - विन्यास

निम्नलिखित DELETE FROM के लिए सामान्य वाक्यविन्यास है।

DELETE FROM  <tablename> 
[WHERE condition];

उदाहरण

निम्न उदाहरण तालिका कर्मचारी से 101 कर्मचारी को हटा देता है।

DELETE FROM Employee 
WHERE EmployeeNo = 101;

निम्न आउटपुट में, आप देख सकते हैं कि कर्मचारी 101 तालिका से हटा दिया गया है।

SELECT EmployeeNo FROM Employee;  
*** Query completed. No rows found. 
*** Total elapsed time was 1 second.

नियमों

  • आप तालिका के एक या अधिक रिकॉर्ड अपडेट कर सकते हैं।

  • यदि कोई शर्त निर्दिष्ट नहीं है, तो तालिका की सभी पंक्तियाँ हटा दी जाती हैं।

  • आप किसी तालिका को अन्य तालिका से मानों के साथ अपडेट कर सकते हैं।

सेलेक्ट स्टेटमेंट का उपयोग टेबल से रिकॉर्ड प्राप्त करने के लिए किया जाता है।

वाक्य - विन्यास

निम्नलिखित चयन कथन का मूल सिंटैक्स है।

SELECT 
column 1, column 2, ..... 
FROM  
tablename;

उदाहरण

निम्नलिखित कर्मचारी तालिका पर विचार करें।

कर्मचारी संख्या पहला नाम उपनाम JoinedDate DepartmentNo जन्म दिन
101 माइक जेम्स 2005/03/27 1 1980/01/05
102 रॉबर्ट विलियम्स 2007/04/25 2 1983/03/05
103 पीटर पॉल 2007/03/21 2 1983/04/01
104 एलेक्स स्टुअर्ट 2008/02/01 2 1984/11/06
105 रॉबर्ट जेम्स 2008/01/04 3 1984/12/01

निम्नलिखित SELECT स्टेटमेंट का एक उदाहरण है।

SELECT EmployeeNo,FirstName,LastName 
FROM Employee;

जब इस क्वेरी को निष्पादित किया जाता है, तो यह कर्मचारी तालिका से EmployeeNo, FirstName और LastName कॉलम प्राप्त करता है।

EmployeeNo            FirstName                       LastName 
-----------  ------------------------------  --------------------------- 
   101                   Mike                            James 
   104                   Alex                            Stuart 
   102                   Robert                          Williams 
   105                   Robert                          James 
   103                   Peter                           Paul

यदि आप किसी तालिका से सभी कॉलम लाना चाहते हैं, तो आप सभी कॉलमों को सूचीबद्ध करने के बजाय निम्नलिखित कमांड का उपयोग कर सकते हैं।

SELECT * FROM Employee;

उपरोक्त क्वेरी कर्मचारी तालिका से सभी रिकॉर्ड प्राप्त करेगी।

कहां कारण

जहां खंड का चयन SELECT स्टेटमेंट द्वारा दिए गए रिकॉर्ड को फिल्टर करने के लिए किया जाता है। एक शर्त WHERE क्लॉज से जुड़ी है। केवल, जो रिकॉर्ड WHERE क्लॉज में स्थिति को संतुष्ट करते हैं, उन्हें वापस कर दिया जाता है।

वाक्य - विन्यास

इसके बाद सेलेक्ट स्टेटमेंट का सिंटैक्स WHERE क्लॉज के साथ है।

SELECT * FROM tablename 
WHERE[condition];

उदाहरण

निम्न क्वेरी रिकॉर्ड प्राप्त करती है जहां EmploeeNo 101 है।

SELECT * FROM Employee 
WHERE EmployeeNo = 101;

जब इस क्वेरी को निष्पादित किया जाता है, तो यह निम्नलिखित रिकॉर्ड लौटाता है।

EmployeeNo          FirstName                      LastName 
----------- ------------------------------ ----------------------------- 
   101                 Mike                           James

द्वारा आदेश

जब चयन कथन निष्पादित किया जाता है, तो दी गई पंक्तियाँ किसी विशेष क्रम में नहीं होती हैं। ORDER BY क्लॉज का उपयोग किसी भी कॉलम पर आरोही / अवरोही क्रम में रिकॉर्ड को व्यवस्थित करने के लिए किया जाता है।

वाक्य - विन्यास

निम्न क्रम खंड के साथ चयन कथन का वाक्य विन्यास है।

SELECT * FROM tablename 
ORDER BY column 1, column 2..;

उदाहरण

निम्न क्वेरी कर्मचारी तालिका से रिकॉर्ड प्राप्त करती है और FirstName द्वारा परिणाम का आदेश देती है।

SELECT * FROM Employee 
ORDER BY FirstName;

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्न आउटपुट का उत्पादन करती है।

EmployeeNo         FirstName                      LastName 
----------- ------------------------------ ----------------------------- 
    104               Alex                           Stuart 
    101               Mike                           James 
    103               Peter                          Paul 
    102               Robert                         Williams 
    105               Robert                         James

समूह द्वारा

ग्रुप बाय क्लॉज का चयन सेलेक्ट स्टेटमेंट के साथ किया जाता है और समूहों में इसी तरह के रिकॉर्ड की व्यवस्था करता है।

वाक्य - विन्यास

निम्नलिखित ग्रुप बाय क्लॉज के साथ सेलेक्ट स्टेटमेंट का सिंटैक्स है।

SELECT column 1, column2 …. FROM tablename 
GROUP BY column 1, column 2..;

उदाहरण

निम्नलिखित उदाहरण डिपार्टमेंटनॉ कॉलम द्वारा रिकॉर्ड्स को समूहीकृत करता है और प्रत्येक विभाग से कुल गणना की पहचान करता है।

SELECT DepartmentNo,Count(*) FROM   
Employee 
GROUP BY DepartmentNo;

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्न आउटपुट का उत्पादन करती है।

DepartmentNo    Count(*) 
------------  ----------- 
     3             1 
     1             1 
     2             3

Teradata निम्नलिखित तार्किक और सशर्त ऑपरेटरों का समर्थन करता है। इन ऑपरेटरों का उपयोग तुलना करने और कई स्थितियों को संयोजित करने के लिए किया जाता है।

वाक्य - विन्यास जिसका अर्थ है
> से अधिक
< से कम
>= इससे बड़ा या इसके बराबर
<= से कम या बराबर
= के बराबर
BETWEEN यदि मान सीमा के भीतर है
IN यदि मान <अभिव्यक्ति> में हैं
NOT IN यदि मान <अभिव्यक्ति> में नहीं हैं
IS NULL यदि मान NULL है
IS NOT NULL यदि मान पूर्ण नहीं है
AND कई शर्तों को मिलाएं। सभी शर्तों को पूरा करने पर ही सही मूल्यांकन होता है
OR कई शर्तों को मिलाएं। या तो शर्तों को पूरा करने पर ही सही मूल्यांकन होता है।
NOT स्थिति का अर्थ उलट देता है

के बीच

अगर कोई मान मानों की सीमा के भीतर है, तो जाँच करने के लिए BETWEEN कमांड का उपयोग किया जाता है।

उदाहरण

निम्नलिखित कर्मचारी तालिका पर विचार करें।

कर्मचारी संख्या पहला नाम उपनाम JoinedDate DepartmentNo जन्म दिन
101 माइक जेम्स 2005/03/27 1 1980/01/05
102 रॉबर्ट विलियम्स 2007/04/25 2 1983/03/05
103 पीटर पॉल 2007/03/21 2 1983/04/01
104 एलेक्स स्टुअर्ट 2008/02/01 2 1984/11/06
105 रॉबर्ट जेम्स 2008/01/04 3 1984/12/01

निम्नलिखित उदाहरण 101,102 और 103 के बीच सीमा में कर्मचारी संख्या के साथ रिकॉर्ड प्राप्त करते हैं।

SELECT EmployeeNo, FirstName FROM  
Employee 
WHERE EmployeeNo BETWEEN 101 AND 103;

जब उपरोक्त क्वेरी निष्पादित की जाती है, तो यह कर्मचारी रिकॉर्ड को 101 और 103 के बीच कर्मचारी संख्या के साथ वापस करता है।

*** Query completed. 3 rows found. 2 columns returned. 
*** Total elapsed time was 1 second. 
 EmployeeNo            FirstName 
-----------  ------------------------------ 
   101                   Mike 
   102                   Robert 
   103                   Peter

में

मूल्यों की दी गई सूची के खिलाफ मूल्य की जांच करने के लिए कमांड का उपयोग किया जाता है।

उदाहरण

निम्नलिखित उदाहरण 101, 102 और 103 में कर्मचारी संख्या के साथ रिकॉर्ड प्राप्त करते हैं।

SELECT EmployeeNo, FirstName FROM  
Employee 
WHERE EmployeeNo in (101,102,103);

उपरोक्त क्वेरी निम्न रिकॉर्ड लौटाती है।

*** Query completed. 3 rows found. 2 columns returned. 
*** Total elapsed time was 1 second.  
 EmployeeNo            FirstName 
-----------  ------------------------------ 
   101                   Mike 
   102                   Robert 
   103                   Peter

अंदर नही

IN कमांड में IN कमांड का परिणाम उल्टा नहीं होता है। यह उन मानों के साथ रिकॉर्ड प्राप्त करता है जो दी गई सूची से मेल नहीं खाते हैं।

उदाहरण

निम्नलिखित उदाहरण 101, 102 और 103 में कर्मचारी संख्या के साथ रिकॉर्ड प्राप्त करते हैं।

SELECT * FROM  
Employee 
WHERE EmployeeNo not in (101,102,103);

उपरोक्त क्वेरी निम्न रिकॉर्ड लौटाती है।

*** Query completed. 2 rows found. 6 columns returned. 
*** Total elapsed time was 1 second. 
 EmployeeNo          FirstName                      LastName 
----------- ------------------------------ -----------------------------    
    104                Alex                          Stuart 
    105                Robert                        James

SET ऑपरेटर्स कई सेलेक्ट स्टेटमेंट के परिणाम जोड़ते हैं। यह जॉइंट्स के समान दिख सकता है, लेकिन जॉइन्ट्स कई टेबलों से कॉम्बिनेशन को जोड़ती है जबकि SET ऑपरेटर्स कई रो से रो को जोड़ती है।

नियमों

  • प्रत्येक SELECT स्टेटमेंट से कॉलम की संख्या समान होनी चाहिए।

  • प्रत्येक SELECT से डेटा प्रकार संगत होना चाहिए।

  • ORDER BY को केवल अंतिम चयन विवरण में शामिल किया जाना चाहिए।

संघ

UNION स्टेटमेंट का उपयोग कई सेलेक्ट स्टेटमेंट्स के परिणामों को संयोजित करने के लिए किया जाता है। यह डुप्लिकेट को अनदेखा करता है।

वाक्य - विन्यास

निम्नलिखित UNION स्टेटमेंट का मूल सिंटैक्स है।

SELECT col1, col2, col3… 
FROM  
<table 1> 
[WHERE condition] 
UNION  

SELECT col1, col2, col3… 
FROM  
<table 2> 
[WHERE condition];

उदाहरण

निम्नलिखित कर्मचारी तालिका और वेतन तालिका पर विचार करें।

कर्मचारी संख्या पहला नाम उपनाम JoinedDate DepartmentNo जन्म दिन
101 माइक जेम्स 2005/03/27 1 1980/01/05
102 रॉबर्ट विलियम्स 2007/04/25 2 1983/03/05
103 पीटर पॉल 2007/03/21 2 1983/04/01
104 एलेक्स स्टुअर्ट 2008/02/01 2 1984/11/06
105 रॉबर्ट जेम्स 2008/01/04 3 1984/12/01
कर्मचारी संख्या कुल कटौती कुल भुगतान
101 40,000 4000 36,000
102 80,000 6000 74,000
103 90,000 7000 83,000
104 75,000 5000 70,000

निम्न UNION क्वेरी कर्मचारी और वेतन तालिका दोनों से EmployeeNo मान को जोड़ती है।

SELECT EmployeeNo 
FROM  
Employee 
UNION 

SELECT EmployeeNo 
FROM  
Salary;

जब क्वेरी निष्पादित की जाती है, तो यह निम्न आउटपुट का उत्पादन करती है।

EmployeeNo 
----------- 
   101 
   102 
   103 
   104 
   105

यूनिअन ऑल

UNION सभी कथन UNION के समान है, यह डुप्लिकेट पंक्तियों सहित कई तालिकाओं के परिणामों को जोड़ता है।

वाक्य - विन्यास

निम्नलिखित यूनिअन ऑल स्टेटमेंट का मूल सिंटैक्स है।

SELECT col1, col2, col3… 
FROM  
<table 1> 
[WHERE condition] 
UNION ALL 

SELECT col1, col2, col3…
FROM  
<table 2> 
[WHERE condition];

उदाहरण

निम्नलिखित यूनिअन ऑल स्टेटमेंट के लिए एक उदाहरण है।

SELECT EmployeeNo 
FROM  
Employee 
UNION ALL 

SELECT EmployeeNo 
FROM  
Salary;

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्न आउटपुट का उत्पादन करती है। आप देख सकते हैं कि यह डुप्लिकेट भी लौटाता है।

EmployeeNo 
----------- 
    101 
    104 
    102 
    105 
    103 
    101 
    104 
    102 
    103

एक दूसरे को काटना

INTERSECT कमांड का उपयोग कई सेलेक्ट स्टेटमेंट के परिणामों को संयोजित करने के लिए भी किया जाता है। यह पहले सेलेक्ट स्टेटमेंट से उन पंक्तियों को लौटाता है जिनका दूसरे सेलेक्ट स्टेटमेंट में मैच होता है। दूसरे शब्दों में, यह उन पंक्तियों को लौटाता है जो दोनों चयन कथनों में मौजूद हैं।

वाक्य - विन्यास

निम्नलिखित इंटरसेक्ट स्टेटमेंट का मूल सिंटैक्स है।

SELECT col1, col2, col3… 
FROM  
<table 1>
[WHERE condition] 
INTERSECT 

SELECT col1, col2, col3… 
FROM  
<table 2> 
[WHERE condition];

उदाहरण

निम्नलिखित INTERSECT स्टेटमेंट का एक उदाहरण है। यह दोनों तालिकाओं में मौजूद EmployeeNo मान देता है।

SELECT EmployeeNo 
FROM  
Employee 
INTERSECT 

SELECT EmployeeNo 
FROM  
Salary;

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्नलिखित रिकॉर्ड लौटाता है। कर्मचारी 105 को बाहर रखा गया है क्योंकि यह सैलरी टेबल में मौजूद नहीं है।

EmployeeNo 
----------- 
   101 
   104 
   102 
   103

माइनस / छोड़कर

MINUS / EXCEPT कमांड कई तालिकाओं से पंक्तियों को जोड़ते हैं और उन पंक्तियों को वापस करते हैं जो पहले SELECT में हैं लेकिन दूसरे SELECT में नहीं हैं। वे दोनों एक ही परिणाम लौटाते हैं।

वाक्य - विन्यास

निम्नलिखित MINUS कथन का मूल सिंटैक्स है।

SELECT col1, col2, col3… 
FROM  
<table 1> 
[WHERE condition] 
MINUS 

SELECT col1, col2, col3… 
FROM  
<table 2> 
[WHERE condition];

उदाहरण

निम्नलिखित MINUS कथन का एक उदाहरण है।

SELECT EmployeeNo 
FROM  
Employee 
MINUS 

SELECT EmployeeNo 
FROM  
Salary;

जब इस क्वेरी को निष्पादित किया जाता है, तो यह निम्नलिखित रिकॉर्ड लौटाता है।

EmployeeNo 
----------- 
   105

टेराडाटा स्ट्रिंग्स में हेरफेर करने के लिए कई कार्य प्रदान करता है। ये कार्य ANSI मानक के अनुकूल हैं।

अनु क्रमांक स्ट्रिंग फंक्शन और विवरण
1 ||

एक साथ तार जुड़े

2 SUBSTR

एक तार का एक हिस्सा निकालता है (Teradata एक्सटेंशन)

3 SUBSTRING

एक स्ट्रिंग (ANSI मानक) के एक हिस्से को निकालता है

4 INDEX

एक स्ट्रिंग में एक चरित्र की स्थिति का पता लगाता है (Teradata एक्सटेंशन)

5 POSITION

एक स्ट्रिंग में एक चरित्र की स्थिति का पता लगाता है (ANSI मानक)

6 TRIM

तार एक तार से खाली हो जाता है

7 UPPER

एक स्ट्रिंग को अपरकेस में परिवर्तित करता है

8 LOWER

एक स्ट्रिंग को लोअरकेस में परिवर्तित करता है

उदाहरण

निम्नलिखित तालिका परिणामों के साथ कुछ स्ट्रिंग फ़ंक्शंस सूचीबद्ध करती है।

स्ट्रिंग फ़ंक्शन परिणाम
चुनें (4 से 1 के लिए गोदाम) वेयर
चयन करें ('गोदाम', 1,4) वेयर
'डेटा' का चयन करें || '' || 'गोदाम' डेटा वेयरहाउस
चयनित UPPER ('डेटा') डेटा
सेलेक्ट लोअर ('डेटा') डेटा

यह अध्याय टेराडाटा में उपलब्ध तिथि / समय के कार्यों पर चर्चा करता है।

दिनांक संग्रहण

निम्न सूत्र का उपयोग करके तिथियों को पूर्णांक के रूप में संग्रहीत किया जाता है।

((YEAR - 1900) * 10000) + (MONTH * 100) + DAY

दिनांक कैसे संग्रहीत किए जाते हैं, यह जांचने के लिए आप निम्न क्वेरी का उपयोग कर सकते हैं।

SELECT CAST(CURRENT_DATE AS INTEGER);

चूंकि तिथियां पूर्णांक के रूप में संग्रहीत की जाती हैं, आप उन पर कुछ अंकगणितीय संचालन कर सकते हैं। टेराडाटा इन कार्यों को करने के लिए कार्य प्रदान करता है।

उद्धरण

EXTRACT फंक्शन, DATE मान से दिन, महीने और वर्ष के भाग को अर्क करता है। इस फ़ंक्शन का उपयोग TIME / TIMESTAMP मान से घंटा, मिनट और दूसरा निकालने के लिए भी किया जाता है।

उदाहरण

निम्नलिखित उदाहरण दिखाते हैं कि कैसे साल, महीना, तारीख, घंटा, मिनट और टाइमस्टैम्प मूल्यों से दूसरे मान निकालें।

SELECT EXTRACT(YEAR FROM CURRENT_DATE);  
EXTRACT(YEAR FROM Date) 
----------------------- 
        2016  
SELECT EXTRACT(MONTH FROM CURRENT_DATE);  
EXTRACT(MONTH FROM Date) 
------------------------ 
          1        
SELECT EXTRACT(DAY FROM CURRENT_DATE);  
EXTRACT(DAY FROM Date) 
------------------------ 
          1    
       
SELECT EXTRACT(HOUR FROM CURRENT_TIMESTAMP);  
EXTRACT(HOUR FROM Current TimeStamp(6)) 
--------------------------------------- 
                 4      
SELECT EXTRACT(MINUTE FROM CURRENT_TIMESTAMP);  
EXTRACT(MINUTE FROM Current TimeStamp(6)) 
----------------------------------------- 
                 54  
SELECT EXTRACT(SECOND FROM CURRENT_TIMESTAMP);  
EXTRACT(SECOND FROM Current TimeStamp(6)) 
----------------------------------------- 
              27.140000

मध्यान्तर

Teradata DATE और TIME मान पर अंकगणितीय कार्य करने के लिए INTERVAL फ़ंक्शन प्रदान करता है। दो प्रकार के INTERVAL फ़ंक्शंस हैं।

साल-महीने का अंतराल

  • YEAR
  • महीने से पहले
  • MONTH

दिन-समय अंतराल

  • DAY
  • दिन के लिए दिन
  • दिन से दिन
  • सेकंड के लिए दिन
  • HOUR
  • मिनट के लिए
  • सेकंड के लिए
  • MINUTE
  • सेकंड के लिए मिनट
  • SECOND

उदाहरण

निम्न उदाहरण वर्तमान तिथि में 3 वर्ष जोड़ता है।

SELECT CURRENT_DATE, CURRENT_DATE + INTERVAL '03' YEAR; 
  Date    (Date+ 3) 
--------  --------- 
16/01/01   19/01/01

निम्न उदाहरण वर्तमान तिथि में 3 साल और 01 महीने जोड़ता है।

SELECT CURRENT_DATE, CURRENT_DATE + INTERVAL '03-01' YEAR TO MONTH; 
 Date     (Date+ 3-01) 
--------  ------------ 
16/01/01    19/02/01

निम्न उदाहरण वर्तमान टाइमस्टैम्प में 01 दिन, 05 घंटे और 10 मिनट जोड़ता है।

SELECT CURRENT_TIMESTAMP,CURRENT_TIMESTAMP + INTERVAL '01 05:10' DAY TO MINUTE; 
     Current TimeStamp(6)         (Current TimeStamp(6)+ 1 05:10) 
--------------------------------  -------------------------------- 
2016-01-01 04:57:26.360000+00:00  2016-01-02 10:07:26.360000+00:00

Teradata अंतर्निहित कार्य प्रदान करता है जो SQL के लिए एक्सटेंशन हैं। निम्नलिखित सामान्य निर्मित कार्य हैं।

समारोह परिणाम
तारीख़ चुनें; दिनांक
--------
16/01/01
CURRENT_DATE का चयन करें; दिनांक
--------
16/01/01
चयनित समय; समय
--------
04:50:29
CURRENT_TIME का चयन करें; समय
--------
04:50:29
CURRENT_TIMESTAMP का चयन करें; वर्तमान टाइमस्टैम्प (6)
--------------------------------
2016-01-01 04: 51: 06.990000 + 00: 00
DATABASE का चयन करें; डेटाबेस
------------------------------
TDUSER

टेराडाटा सामान्य कुल कार्यों का समर्थन करता है। उनका चयन SELECT स्टेटमेंट के साथ किया जा सकता है।

  • COUNT - पंक्तियों को गिनता है

  • SUM - निर्दिष्ट कॉलम (मानों) के मानों को पूरा करें

  • MAX - निर्दिष्ट कॉलम का बड़ा मूल्य लौटाता है

  • MIN - निर्दिष्ट कॉलम का न्यूनतम मूल्य लौटाता है

  • AVG - निर्दिष्ट कॉलम का औसत मूल्य लौटाता है

उदाहरण

निम्नलिखित वेतन तालिका पर विचार करें।

कर्मचारी संख्या कुल कटौती कुल भुगतान
101 40,000 4000 36,000
104 75,000 5000 70,000
102 80,000 6000 74,000
105 70,000 4000 66,000
103 90,000 7000 83,000

गिनती

निम्न उदाहरण वेतन तालिका में रिकॉर्ड की संख्या को गिना जाता है।

SELECT count(*) from Salary;  

  Count(*) 
----------- 
    5

मैक्स

निम्न उदाहरण अधिकतम कर्मचारी शुद्ध वेतन मान देता है।

SELECT max(NetPay) from Salary;   
   Maximum(NetPay) 
--------------------- 
       83000

मिनट

निम्न उदाहरण वेतन तालिका से न्यूनतम कर्मचारी शुद्ध वेतन मान देता है।

SELECT min(NetPay) from Salary;   

   Minimum(NetPay) 
--------------------- 
        36000

औसत

निम्न उदाहरण तालिका से कर्मचारियों का औसत वेतन मान लौटाता है।

SELECT avg(NetPay) from Salary; 
  
   Average(NetPay) 
--------------------- 
       65800

योग

निम्नलिखित उदाहरण वेतन तालिका के सभी रिकॉर्ड से कर्मचारियों के शुद्ध वेतन की गणना करता है।

SELECT sum(NetPay) from Salary;
  
   Sum(NetPay) 
----------------- 
     329000

यह अध्याय टेराडाटा के मामले और कौशल कार्यों की व्याख्या करता है।

मामले की अभिव्यक्ति

CASE अभिव्यक्ति एक शर्त या WHEN क्लॉज़ के विरुद्ध प्रत्येक पंक्ति का मूल्यांकन करती है और पहले मैच का परिणाम देती है। यदि कोई मिलान नहीं है, तो ईएलएसई भाग से परिणाम लौटाया जाता है।

वाक्य - विन्यास

निम्नलिखित CASE अभिव्यक्ति का वाक्यविन्यास है।

CASE <expression> 
WHEN <expression> THEN result-1 
WHEN <expression> THEN result-2 

ELSE  
   Result-n 
END

उदाहरण

निम्नलिखित कर्मचारी तालिका पर विचार करें।

कर्मचारी संख्या पहला नाम उपनाम JoinedDate DepartmentNo जन्म दिन
101 माइक जेम्स 2005/03/27 1 1980/01/05
102 रॉबर्ट विलियम्स 2007/04/25 2 1983/03/05
103 पीटर पॉल 2007/03/21 2 1983/04/01
104 एलेक्स Stuart 2/1/2008 2 11/6/1984
105 Robert James 1/4/2008 3 12/1/1984

The following example evaluates the DepartmentNo column and returns value of 1 if the department number is 1; returns 2 if the department number is 3; otherwise it returns value as invalid department.

SELECT 
   EmployeeNo, 
CASE DepartmentNo 
   WHEN 1 THEN 'Admin' 
   WHEN 2 THEN 'IT' 
ELSE 'Invalid Dept'
   END AS Department 
FROM Employee;

When the above query is executed, it produces the following output.

*** Query completed. 5 rows found. 2 columns returned. 
*** Total elapsed time was 1 second. 
 EmployeeNo    Department 
-----------   ------------ 
   101         Admin 
   104         IT 
   102         IT 
   105         Invalid Dept 
   103         IT

The above CASE expression can also be written in the following form which will produce the same result as above.

SELECT 
   EmployeeNo, 
CASE  
   WHEN DepartmentNo = 1 THEN 'Admin' 
   WHEN  DepartmentNo = 2 THEN 'IT' 
ELSE 'Invalid Dept' 
   END AS Department  
FROM Employee;

COALESCE

COALESCE is a statement that returns the first non-null value of the expression. It returns NULL if all the arguments of the expression evaluates to NULL. Following is the syntax.

Syntax

COALESCE(expression 1, expression 2, ....)

Example

SELECT 
   EmployeeNo, 
   COALESCE(dept_no, 'Department not found') 
FROM  
   employee;

NULLIF

NULLIF statement returns NULL if the arguments are equal.

Syntax

Following is the syntax of the NULLIF statement.

NULLIF(expression 1, expression 2)

Example

The following example returns NULL if the DepartmentNo is equal to 3. Otherwise, it returns the DepartmentNo value.

SELECT 
   EmployeeNo,  
   NULLIF(DepartmentNo,3) AS department 
FROM Employee;

The above query returns the following records. You can see that employee 105 has department no. as NULL.

*** Query completed. 5 rows found. 2 columns returned. 
*** Total elapsed time was 1 second. 
 EmployeeNo      department 
-----------  ------------------ 
    101              1 
    104              2 
    102              2 
    105              ? 
    103              2

Primary index is used to specify where the data resides in Teradata. It is used to specify which AMP gets the data row. Each table in Teradata is required to have a primary index defined. If the primary index is not defined, Teradata automatically assigns the primary index. Primary index provides the fastest way to access the data. A primary may have a maximum of 64 columns.

Primary index is defined while creating a table. There are 2 types of Primary Indexes.

  • Unique Primary Index(UPI)
  • Non Unique Primary Index(NUPI)

Unique Primary Index (UPI)

If the table is defined to be having UPI, then the column deemed as UPI should not have any duplicate values. If any duplicate values are inserted, they will be rejected.

Create Unique Primary Index

The following example creates the Salary table with column EmployeeNo as Unique Primary Index.

CREATE SET TABLE Salary ( 
   EmployeeNo INTEGER, 
   Gross INTEGER,  
   Deduction INTEGER, 
   NetPay INTEGER 
) 
UNIQUE PRIMARY INDEX(EmployeeNo);

Non Unique Primary Index (NUPI)

If the table is defined to be having NUPI, then the column deemed as UPI can accept duplicate values.

Create Non Unique Primary Index

The following example creates the employee accounts table with column EmployeeNo as Non Unique Primary Index. EmployeeNo is defined as Non Unique Primary Index since an employee can have multiple accounts in the table; one for salary account and another one for reimbursement account.

CREATE SET TABLE Employee _Accounts ( 
   EmployeeNo INTEGER, 
   employee_bank_account_type BYTEINT. 
   employee_bank_account_number INTEGER, 
   employee_bank_name VARCHAR(30), 
   employee_bank_city VARCHAR(30) 
) 
PRIMARY INDEX(EmployeeNo);

Join is used to combine records from more than one table. Tables are joined based on the common columns/values from these tables.

There are different types of Joins available.

  • Inner Join
  • Left Outer Join
  • Right Outer Join
  • Full Outer Join
  • Self Join
  • Cross Join
  • Cartesian Production Join

INNER JOIN

Inner Join combines records from multiple tables and returns the values that exist in both the tables.

Syntax

Following is the syntax of the INNER JOIN statement.

SELECT col1, col2, col3…. 
FROM  
Table-1 
INNER JOIN 
Table-2 
ON (col1 = col2) 
<WHERE condition>;

Example

Consider the following employee table and salary table.

EmployeeNo FirstName LastName JoinedDate DepartmentNo BirthDate
101 Mike James 3/27/2005 1 1/5/1980
102 Robert Williams 4/25/2007 2 3/5/1983
103 Peter Paul 3/21/2007 2 4/1/1983
104 Alex Stuart 2/1/2008 2 11/6/1984
105 Robert James 1/4/2008 3 12/1/1984
EmployeeNo Gross Deduction NetPay
101 40,000 4,000 36,000
102 80,000 6,000 74,000
103 90,000 7,000 83,000
104 75,000 5,000 70,000

The following query joins the Employee table and Salary table on the common column EmployeeNo. Each table is assigned an alias A & B and the columns are referenced with the correct alias.

SELECT A.EmployeeNo, A.DepartmentNo, B.NetPay 
FROM  
Employee A 
INNER JOIN 
Salary B 
ON (A.EmployeeNo = B. EmployeeNo);

When the above query is executed, it returns the following records. Employee 105 is not included in the result since it doesn’t have matching records in the Salary table.

*** Query completed. 4 rows found. 3 columns returned. 
*** Total elapsed time was 1 second. 
 EmployeeNo   DepartmentNo     NetPay 
-----------  ------------   ----------- 
    101           1            36000 
    102           2            74000 
    103           2            83000 
    104           2            70000

OUTER JOIN

LEFT OUTER JOIN and RIGHT OUTER JOIN also combine the results from multiple table.

  • LEFT OUTER JOIN returns all the records from the left table and returns only the matching records from the right table.

  • RIGHT OUTER JOIN returns all the records from the right table and returns only matching rows from the left table.

  • FULL OUTER JOIN combines the results from both LEFT OUTER and RIGHT OUTER JOINS. It returns both matching and non-matching rows from the joined tables.

Syntax

Following is the syntax of the OUTER JOIN statement. You need to use one of the options from LEFT OUTER JOIN, RIGHT OUTER JOIN or FULL OUTER JOIN.

SELECT col1, col2, col3…. 
FROM  
Table-1 
LEFT OUTER JOIN/RIGHT OUTER JOIN/FULL OUTER JOIN 
Table-2 
ON (col1 = col2) 
<WHERE condition>;

Example

Consider the following example of the LEFT OUTER JOIN query. It returns all the records from Employee table and matching records from Salary table.

SELECT A.EmployeeNo, A.DepartmentNo, B.NetPay 
FROM  
Employee A 
LEFT OUTER JOIN 
Salary B 
ON (A.EmployeeNo = B. EmployeeNo) 
ORDER BY A.EmployeeNo;

When the above query is executed, it produces the following output. For employee 105, NetPay value is NULL, since it doesn’t have matching records in Salary table.

*** Query completed. 5 rows found. 3 columns returned. 
*** Total elapsed time was 1 second. 
 EmployeeNo  DepartmentNo     NetPay 
-----------  ------------   ----------- 
    101           1           36000 
    102           2           74000 
    103           2           83000 
    104           2           70000 
    105           3             ?

CROSS JOIN

Cross Join joins every row from the left table to every row from the right table.

Syntax

Following is the syntax of the CROSS JOIN statement.

SELECT A.EmployeeNo, A.DepartmentNo, B.EmployeeNo,B.NetPay 
FROM  
Employee A 
CROSS JOIN 
Salary B 
WHERE A.EmployeeNo = 101 
ORDER BY B.EmployeeNo;

When the above query is executed, it produces the following output. Employee No 101 from Employee table is joined with each and every record from Salary Table.

*** Query completed. 4 rows found. 4 columns returned. 
*** Total elapsed time was 1 second. 
 EmployeeNo  DepartmentNo   EmployeeNo    NetPay 
-----------  ------------  -----------  ----------- 
    101           1            101         36000 
    101           1            104         70000 
    101           1            102         74000 
    101           1            103         83000

A subquery returns records from one table based on the values from another table. It is a SELECT query within another query. The SELECT query called as inner query is executed first and the result is used by the outer query. Some of its salient features are −

  • A query can have multiple subqueries and subqueries may contain another subquery.

  • Subqueries doesn't return duplicate records.

  • If subquery returns only one value, you can use = operator to use it with the outer query. If it returns multiple values you can use IN or NOT IN.

Syntax

Following is the generic syntax of subqueries.

SELECT col1, col2, col3,… 
FROM  
Outer Table 
WHERE col1 OPERATOR ( Inner SELECT Query);

Example

Consider the following Salary table.

EmployeeNo Gross Deduction NetPay
101 40,000 4,000 36,000
102 80,000 6,000 74,000
103 90,000 7,000 83,000
104 75,000 5,000 70,000

The following query identifies the employee number with highest salary. The inner SELECT performs the aggregation function to return the maximum NetPay value and the outer SELECT query uses this value to return the employee record with this value.

SELECT EmployeeNo, NetPay 
FROM Salary 
WHERE NetPay =  
(SELECT MAX(NetPay)  
FROM Salary);

जब इस क्वेरी को निष्पादित किया जाता है, तो यह निम्न आउटपुट का उत्पादन करता है।

*** Query completed. One row found. 2 columns returned. 
*** Total elapsed time was 1 second.  
 EmployeeNo     NetPay 
-----------  ----------- 
    103         83000

अस्थायी डेटा रखने के लिए टेराडाटा निम्नलिखित तालिका प्रकारों का समर्थन करता है।

  • व्युत्पन्न तालिका
  • अस्थिर तालिका
  • वैश्विक अस्थायी तालिका

व्युत्पन्न तालिका

व्युत्पन्न तालिकाओं को एक क्वेरी के भीतर बनाया, उपयोग और गिराया जाता है। ये एक क्वेरी के भीतर मध्यवर्ती परिणामों को संग्रहीत करने के लिए उपयोग किया जाता है।

उदाहरण

निम्न उदाहरण 75000 से अधिक वेतन वाले कर्मचारियों के रिकॉर्ड के साथ एक व्युत्पन्न तालिका EmpSal बनाता है।

SELECT 
Emp.EmployeeNo, 
Emp.FirstName, 
Empsal.NetPay 
FROM 
Employee Emp, 
(select EmployeeNo , NetPay 
from Salary
where NetPay >= 75000) Empsal 
where Emp.EmployeeNo = Empsal.EmployeeNo;

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह कर्मचारियों को 75000 से अधिक वेतन देता है।

*** Query completed. One row found. 3 columns returned. 
*** Total elapsed time was 1 second. 
 EmployeeNo            FirstName               NetPay 
-----------  ------------------------------  ----------- 
    103                  Peter                 83000

अस्थिर तालिका

वाष्पशील टेबल एक उपयोगकर्ता सत्र के भीतर बनाए, उपयोग और गिराए जाते हैं। उनकी परिभाषा डेटा शब्दकोश में संग्रहीत नहीं है। वे क्वेरी का मध्यवर्ती डेटा रखते हैं जो अक्सर उपयोग किया जाता है। निम्नलिखित वाक्य रचना है।

वाक्य - विन्यास

CREATE [SET|MULTISET] VOALTILE TABLE tablename 
<table definitions> 
<column definitions> 
<index definitions> 
ON COMMIT [DELETE|PRESERVE] ROWS

उदाहरण

CREATE VOLATILE TABLE dept_stat ( 
   dept_no INTEGER, 
   avg_salary INTEGER, 
   max_salary INTEGER, 
   min_salary INTEGER 
) 
PRIMARY INDEX(dept_no) 
ON COMMIT PRESERVE ROWS;

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्न आउटपुट का उत्पादन करती है।

*** Table has been created. 
*** Total elapsed time was 1 second.

वैश्विक अस्थायी तालिका

ग्लोबल टेम्परेरी टेबल की परिभाषा डेटा डिक्शनरी में संग्रहित है और उनका उपयोग कई उपयोगकर्ताओं / सत्रों द्वारा किया जा सकता है। लेकिन वैश्विक अस्थायी तालिका में लोड किए गए डेटा को सत्र के दौरान ही रखा जाता है। आप प्रति सत्र 2000 वैश्विक अस्थायी तालिकाओं तक सामग्री बना सकते हैं। निम्नलिखित वाक्य रचना है।

वाक्य - विन्यास

CREATE [SET|MULTISET] GLOBAL TEMPORARY TABLE tablename 
<table definitions> 
<column definitions> 
<index definitions>

उदाहरण

CREATE SET GLOBAL TEMPORARY TABLE dept_stat ( 
   dept_no INTEGER, 
   avg_salary INTEGER, 
   max_salary INTEGER, 
   min_salary INTEGER 
) 
PRIMARY INDEX(dept_no);

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्न आउटपुट का उत्पादन करती है।

*** Table has been created. 
*** Total elapsed time was 1 second.

टेराडाटा में तीन प्रकार के स्थान उपलब्ध हैं।

स्थायी स्थान

स्थायी स्थान उपयोगकर्ता / डेटाबेस के लिए डेटा पंक्तियों को धारण करने के लिए उपलब्ध अधिकतम स्थान है। स्थायी टेबल, जर्नल, फ़ॉलबैक टेबल और सेकेंडरी इंडेक्स सब-टेबल स्थायी स्थान का उपयोग करते हैं।

स्थायी स्थान डेटाबेस / उपयोगकर्ता के लिए पूर्व-आवंटित नहीं है। वे केवल डेटाबेस / उपयोगकर्ता द्वारा उपयोग किए जा सकने वाले स्थान की अधिकतम मात्रा के रूप में परिभाषित किए जाते हैं। स्थायी स्थान की मात्रा को एएमपी की संख्या से विभाजित किया जाता है। जब भी प्रति एएमपी सीमा पार हो जाती है, एक त्रुटि संदेश उत्पन्न होता है।

स्पूल स्पेस

स्पूल स्पेस अप्रयुक्त स्थायी स्थान है जो सिस्टम द्वारा SQL क्वेरी के मध्यवर्ती परिणाम रखने के लिए उपयोग किया जाता है। स्पूल स्पेस के बिना उपयोगकर्ता किसी भी क्वेरी को निष्पादित नहीं कर सकते हैं।

स्थायी अंतरिक्ष के समान, स्पूल स्पेस उपयोगकर्ता द्वारा उपयोग की जा सकने वाली अधिकतम मात्रा को परिभाषित करता है। स्पूल स्पेस को एएमपी की संख्या से विभाजित किया जाता है। जब भी प्रति एएमपी सीमा पार हो जाती है, तो उपयोगकर्ता को स्पूल स्पेस एरर मिलेगा।

अस्थायी स्थान

Temp space अप्रयुक्त स्थायी स्थान है जो Global Temporary तालिकाओं द्वारा उपयोग किया जाता है। टेम्प स्पेस को AMP की संख्या से भी विभाजित किया जाता है।

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

डेटा को एक्सेस करने के लिए सेकेंडरी इंडेक्स एक वैकल्पिक रास्ता है। प्राथमिक सूचकांक और द्वितीयक सूचकांक के बीच कुछ अंतर हैं।

  • द्वितीयक सूचकांक डेटा वितरण में शामिल नहीं है।

  • द्वितीयक सूचकांक मान उप तालिकाओं में संग्रहीत होते हैं। ये टेबल सभी एएमपी में बनाए गए हैं।

  • द्वितीयक सूचकांक वैकल्पिक हैं।

  • उन्हें टेबल निर्माण के दौरान या टेबल बनाए जाने के बाद बनाया जा सकता है।

  • वे उप-तालिका बनाने के बाद से अतिरिक्त स्थान पर कब्जा कर लेते हैं और उन्हें रखरखाव की भी आवश्यकता होती है क्योंकि उप-तालिकाओं को प्रत्येक नई पंक्ति के लिए अद्यतन करने की आवश्यकता होती है।

दो प्रकार के द्वितीयक सूचकांक हैं -

  • विशिष्ट माध्यमिक सूचकांक (USI)
  • गैर-विशिष्ट माध्यमिक सूचकांक (NUSI)

विशिष्ट माध्यमिक सूचकांक (USI)

एक विशिष्ट माध्यमिक सूचकांक केवल USI के रूप में परिभाषित किए गए स्तंभों के लिए अद्वितीय मूल्यों की अनुमति देता है। USI द्वारा पंक्ति तक पहुँचना एक दो amp ऑपरेशन है।

अद्वितीय माध्यमिक सूचकांक बनाएँ

निम्न उदाहरण कर्मचारी तालिका के EmployeeNo कॉलम पर USI बनाता है।

CREATE UNIQUE INDEX(EmployeeNo) on employee;

गैर विशिष्ट माध्यमिक सूचकांक (NUSI)

एक गैर-अद्वितीय माध्यमिक सूचकांक NUSI के रूप में परिभाषित कॉलम के लिए डुप्लिकेट मानों की अनुमति देता है। NUSI द्वारा पंक्ति तक पहुँचना सभी-amp ऑपरेशन है।

गैर अद्वितीय माध्यमिक सूचकांक बनाएँ

निम्न उदाहरण कर्मचारी तालिका के FirstName स्तंभ पर NUSI बनाता है।

CREATE INDEX(FirstName) on Employee;

Teradata अनुकूलक प्रत्येक SQL क्वेरी के लिए निष्पादन रणनीति के साथ आता है। यह निष्पादन रणनीति SQL क्वेरी के भीतर उपयोग की गई तालिकाओं पर एकत्रित आँकड़ों पर आधारित है। तालिका पर सांख्यिकी संग्रह सांख्यिकी आदेश का उपयोग करके एकत्र किया जाता है। ऑप्टिमाइज़र को इष्टतम निष्पादन रणनीति के साथ आने के लिए पर्यावरण की जानकारी और डेटा जनसांख्यिकी की आवश्यकता होती है।

पर्यावरण की जानकारी

  • नोड्स, एएमपी और सीपीयू की संख्या
  • स्मृति की मात्रा

डेटा जनसांख्यिकी

  • पंक्तियों की संख्या
  • पंक्ति का आकार
  • तालिका में मानों की श्रेणी
  • मूल्य प्रति पंक्तियों की संख्या
  • नल की संख्या

तालिका पर आंकड़े एकत्र करने के लिए तीन दृष्टिकोण हैं।

  • यादृच्छिक एएमपी नमूनाकरण
  • पूर्ण आँकड़े संग्रह
  • SAMPLE विकल्प का उपयोग करना

सांख्यिकी एकत्रित करना

COLLECT STATISTICS कमांड का उपयोग किसी टेबल पर आंकड़े एकत्र करने के लिए किया जाता है।

वाक्य - विन्यास

तालिका पर आंकड़े एकत्र करने के लिए मूल सिंटैक्स है।

COLLECT [SUMMARY] STATISTICS   
INDEX (indexname) COLUMN (columnname) 
ON <tablename>;

उदाहरण

निम्न उदाहरण कर्मचारी तालिका के EmployeeNo कॉलम पर आंकड़े एकत्र करता है।

COLLECT STATISTICS COLUMN(EmployeeNo) ON Employee;

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्न आउटपुट का उत्पादन करती है।

*** Update completed. 2 rows changed. 
*** Total elapsed time was 1 second.

सांख्यिकी देखना

आप एकत्रित सांख्यिकी को HELP STATISTICS कमांड का उपयोग करके देख सकते हैं।

वाक्य - विन्यास

निम्नलिखित आँकड़ों को देखने के लिए सिंटैक्स है।

HELP STATISTICS <tablename>;

उदाहरण

कर्मचारी तालिका पर एकत्रित आँकड़ों को देखने के लिए निम्नलिखित एक उदाहरण है।

HELP STATISTICS employee;

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्नलिखित परिणाम उत्पन्न करता है।

Date       Time      Unique Values           Column Names 
--------   -------- -------------------- ----------------------- 
16/01/01   08:07:04         5                       * 
16/01/01   07:24:16         3                   DepartmentNo 
16/01/01   08:07:04         5                   EmployeeNo

तालिकाओं द्वारा उपयोग किए जाने वाले भंडारण को कम करने के लिए संपीड़न का उपयोग किया जाता है। Teradata में, संपीड़न NULL सहित 255 अलग-अलग मानों को संपीड़ित कर सकता है। चूंकि भंडारण कम हो जाता है, टेराडाटा एक ब्लॉक में अधिक रिकॉर्ड संग्रहीत कर सकता है। यह किसी भी I / O ऑपरेशन के बाद बेहतर क्वेरी प्रतिक्रिया समय में परिणाम प्रति ब्लॉक अधिक पंक्तियों को संसाधित कर सकता है। कंपेट टेबल का उपयोग करके टेबल निर्माण में जोड़ा जा सकता है या टेबल टेबल कमांड के बाद टेबल निर्माण के बाद।

सीमाओं

  • प्रति कॉलम केवल 255 मान संपीड़ित किए जा सकते हैं।
  • प्राथमिक इंडेक्स कॉलम को संपीड़ित नहीं किया जा सकता है।
  • अस्थिर तालिकाओं को संपीड़ित नहीं किया जा सकता है।

बहु-मूल्य संपीड़न (MVC)

निम्न तालिका मान 1, 2 और 3 के लिए फ़ील्ड DepatmentNo को संपीड़ित करती है। जब किसी स्तंभ पर संपीड़न लागू किया जाता है, तो इस स्तंभ के मानों को पंक्ति के साथ संग्रहीत नहीं किया जाता है। इसके बजाय मानों को प्रत्येक एएमपी में टेबल हेडर में संग्रहीत किया जाता है और मूल्य को इंगित करने के लिए केवल उपस्थिति बिट्स को पंक्ति में जोड़ा जाता है।

CREATE SET TABLE employee ( 
   EmployeeNo integer, 
   FirstName CHAR(30), 
   LastName CHAR(30), 
   BirthDate DATE FORMAT 'YYYY-MM-DD-', 
   JoinedDate DATE FORMAT 'YYYY-MM-DD-', 
   employee_gender CHAR(1), 
   DepartmentNo CHAR(02) COMPRESS(1,2,3) 
) 
UNIQUE PRIMARY INDEX(EmployeeNo);

बहु-मूल्य संपीड़न का उपयोग तब किया जा सकता है जब आपके पास परिमित मूल्यों के साथ एक बड़ी तालिका में एक स्तंभ हो।

EXPLAIN कमांड अंग्रेजी में पार्सिंग इंजन की निष्पादन योजना लौटाती है। इसका उपयोग किसी अन्य SQL कथन के अलावा किसी अन्य EXPLAIN कमांड पर किया जा सकता है। जब कोई क्वेरी EXPLAIN कमांड से पहले होती है, तो पार्सिंग इंजन की निष्पादन योजना एएमपी के बजाय उपयोगकर्ता को वापस कर दी जाती है।

उदाहरण के उदाहरण

निम्नलिखित परिभाषा के साथ तालिका कर्मचारी पर विचार करें।

CREATE SET TABLE EMPLOYEE,FALLBACK ( 
   EmployeeNo INTEGER, 
   FirstName VARCHAR(30), 
   LastName VARCHAR(30),
   DOB DATE FORMAT 'YYYY-MM-DD', 
   JoinedDate DATE FORMAT 'YYYY-MM-DD', 
   DepartmentNo BYTEINT 
) 
UNIQUE PRIMARY INDEX ( EmployeeNo );

EXPLAIN योजना के कुछ उदाहरण नीचे दिए गए हैं।

पूर्ण टेबल स्कैन (FTS)

जब SELECT स्टेटमेंट में कोई भी स्थिति निर्दिष्ट नहीं की जाती है, तो ऑप्टिमाइज़र Full Table Scan का उपयोग करने का विकल्प चुन सकता है जहाँ तालिका की प्रत्येक पंक्ति एक्सेस की जाती है।

उदाहरण

निम्नलिखित एक नमूना क्वेरी है जहां ऑप्टिमाइज़र एफटीएस चुन सकता है।

EXPLAIN SELECT * FROM employee;

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्न आउटपुट का उत्पादन करती है। जैसा कि देखा जा सकता है कि अनुकूलक AMP के भीतर सभी AMP और सभी पंक्तियों तक पहुँचने का विकल्प चुनता है।

1) First, we lock a distinct TDUSER."pseudo table" for read on a 
   RowHash to prevent global deadlock for TDUSER.employee.  
2) Next, we lock TDUSER.employee for read.  
3) We do an all-AMPs RETRIEVE step from TDUSER.employee by way of an
   all-rows scan with no residual conditions into Spool 1 
   (group_amps), which is built locally on the AMPs.  The size of 
   Spool 1 is estimated with low confidence to be 2 rows (116 bytes).  
   The estimated time for this step is 0.03 seconds.  
4) Finally, we send out an END TRANSACTION step to all AMPs involved 
   in processing the request. 
→ The contents of Spool 1 are sent back to the user as the result of 
   statement 1.  The total estimated time is 0.03 seconds.

अद्वितीय प्राथमिक सूचकांक

जब यूनिक प्राइमरी इंडेक्स का उपयोग करके पंक्तियों को एक्सेस किया जाता है, तो यह एक एएमपी ऑपरेशन है।

EXPLAIN SELECT * FROM employee WHERE EmployeeNo = 101;

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्न आउटपुट का उत्पादन करती है। जैसा कि देखा जा सकता है कि यह एकल-एएमपी पुनर्प्राप्ति है और आशावादी पंक्ति का उपयोग करने के लिए अद्वितीय प्राथमिक सूचकांक का उपयोग कर रहा है।

1) First, we do a single-AMP RETRIEVE step from TDUSER.employee by 
   way of the unique primary index "TDUSER.employee.EmployeeNo = 101" 
   with no residual conditions. The estimated time for this step is 
   0.01 seconds.  
→ The row is sent directly back to the user as the result of 
   statement 1.  The total estimated time is 0.01 seconds.

अद्वितीय माध्यमिक सूचकांक

जब यूनिक सेकेंडरी इंडेक्स का उपयोग करके पंक्तियों को एक्सेस किया जाता है, तो यह दो एम्पीयर ऑपरेशन होता है।

उदाहरण

निम्नलिखित परिभाषा के साथ तालिका वेतन पर विचार करें।

CREATE SET TABLE SALARY,FALLBACK ( 
   EmployeeNo INTEGER, 
   Gross INTEGER, 
   Deduction INTEGER, 
   NetPay INTEGER 
)
PRIMARY INDEX ( EmployeeNo ) 
UNIQUE INDEX (EmployeeNo);

निम्नलिखित चयन कथन पर विचार करें।

EXPLAIN SELECT * FROM Salary WHERE EmployeeNo = 101;

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्न आउटपुट का उत्पादन करती है। जैसा कि देखा जा सकता है कि ऑप्टिमाइज़र अद्वितीय माध्यमिक सूचकांक का उपयोग करके दो amp ऑपरेशन में पंक्ति को पुनः प्राप्त करता है।

1) First, we do a two-AMP RETRIEVE step from TDUSER.Salary 
   by way of unique index # 4 "TDUSER.Salary.EmployeeNo = 
   101" with no residual conditions.  The estimated time for this 
   step is 0.01 seconds.  
→ The row is sent directly back to the user as the result of 
   statement 1.  The total estimated time is 0.01 seconds.

अतिरिक्त शर्तें

निम्नलिखित EXPLAIN योजना में आमतौर पर देखी गई शर्तों की सूची है।

... (Last Use) …

स्पूल फ़ाइल की अब आवश्यकता नहीं है और यह चरण पूरा होने पर जारी किया जाएगा।

... with no residual conditions …

सभी लागू शर्तों को पंक्तियों पर लागू किया गया है।

... END TRANSACTION …

लेन-देन के ताले जारी किए जाते हैं, और परिवर्तन किए जाते हैं।

... eliminating duplicate rows ...

डुप्लिकेट पंक्तियाँ केवल स्पूल फ़ाइलों में मौजूद होती हैं, तालिकाओं को सेट नहीं करती हैं। DISTINCT ऑपरेशन करना।

... by way of a traversal of index #n extracting row ids only …

एक स्पूल फ़ाइल एक माध्यमिक इंडेक्स (इंडेक्स # एन) में पाई जाने वाली रो आईडी से युक्त होती है।

... we do a SMS (set manipulation step) …

UNION, MINUS या INTERSECT ऑपरेटर का उपयोग करके पंक्तियों को मिलाना।

... which is redistributed by hash code to all AMPs.

जुड़ने की तैयारी में डेटा पुनर्वितरित करना।

... which is duplicated on all AMPs.

शामिल होने की तैयारी में छोटी तालिका (SPOOL के संदर्भ में) से डुप्लिकेटिंग डेटा।

... (one_AMP) or (group_AMPs)

एक एएमपी को इंगित करता है या एएमपी के सबसेट का उपयोग सभी एएमपी के बजाय किया जाएगा।

प्राथमिक इंडेक्स मान के आधार पर एक विशेष AMP को एक पंक्ति सौंपी जाती है। टेराडाटा हैशिंग एल्गोरिथ्म का उपयोग करता है यह निर्धारित करने के लिए कि एएमपी को पंक्ति मिलती है।

निम्नलिखित हैशिंग एल्गोरिथ्म पर एक उच्च स्तरीय आरेख है।

डेटा डालने के लिए निम्नलिखित चरण हैं।

  • क्लाइंट एक क्वेरी सबमिट करता है।

  • पार्सर क्वेरी प्राप्त करता है और हैशिंग एल्गोरिथ्म में रिकॉर्ड का PI मान पास करता है।

  • हैशिंग एल्गोरिथ्म में प्राथमिक सूचकांक मूल्य होता है और रो हैश नामक एक 32 बिट संख्या देता है।

  • हैश मैप प्रविष्टि की पहचान करने के लिए पंक्ति हैश (पहले 16 बिट्स) के उच्च क्रम बिट्स का उपयोग किया जाता है। हैश मैप में एक AMP # होता है। हैश मैप एक प्रकार का बकेट है जिसमें विशिष्ट AMP # होता है।

  • BYNET डेटा को पहचाने गए AMP पर भेजता है।

  • AMP अपने डिस्क के भीतर पंक्ति का पता लगाने के लिए 32 बिट रो हैश का उपयोग करता है।

  • यदि एक ही पंक्ति हैश के साथ कोई रिकॉर्ड है, तो यह विशिष्टता आईडी को बढ़ाता है जो एक 32 बिट संख्या है। नई पंक्ति हैश के लिए, विशिष्टता आईडी को 1 के रूप में असाइन किया गया है और जब भी एक ही पंक्ति हैश के साथ एक रिकॉर्ड डाला जाता है, तो उसे बढ़ाया जाता है।

  • पंक्ति हैश और विशिष्टता आईडी के संयोजन को पंक्ति आईडी कहा जाता है।

  • पंक्ति आईडी डिस्क में प्रत्येक रिकॉर्ड को उपसर्ग करती है।

  • एएमपी में प्रत्येक तालिका पंक्ति तार्किक रूप से उनके रो आईडी द्वारा क्रमबद्ध है।

टेबल्स कैसे स्टोर किए जाते हैं

टेबल्स को उनकी पंक्ति आईडी (पंक्ति हैश + विशिष्टता आईडी) द्वारा क्रमबद्ध किया जाता है और फिर एएमपी के भीतर संग्रहीत किया जाता है। पंक्ति आईडी प्रत्येक डेटा पंक्ति के साथ संग्रहीत की जाती है।

रो हश विशिष्टता आईडी कर्मचारी संख्या पहला नाम उपनाम
2 ए 01 2611 0000 0001 101 माइक जेम्स
2 ए 01 2612 0000 0001 104 एलेक्स स्टुअर्ट
2 ए 01 2613 0000 0001 102 रॉबर्ट विलियम्स
2 ए 01 2614 0000 0001 105 रॉबर्ट जेम्स
2 ए 01 2615 0000 0001 103 पीटर पॉल

JOIN INDEX एक भौतिकवादी दृश्य है। इसकी परिभाषा को स्थायी रूप से संग्रहीत किया जाता है और डेटा तब भी अपडेट किया जाता है जब ज्वाइन इंडेक्स में निर्दिष्ट बेस टेबल को अपडेट किया जाता है। JOIN INDEX में एक या एक से अधिक टेबल हो सकते हैं और पूर्व-एकत्रित डेटा भी हो सकता है। प्रदर्शन में सुधार के लिए ज्वाइन इंडेक्स का उपयोग मुख्य रूप से किया जाता है।

विभिन्न प्रकार के ज्वाइन इंडेक्स उपलब्ध हैं।

  • सिंगल टेबल इंडेक्स इंडेक्स (STJI)
  • मल्टी टेबल जॉइन इंडेक्स (MTJI)
  • एग्रीगेटेड ज्वाइन इंडेक्स (AJI)

सिंगल टेबल इंडेक्स में शामिल हों

सिंगल टेबल ज्वाइन इंडेक्स बेस टेबल से एक की तुलना में अलग-अलग प्राथमिक इंडेक्स कॉलम के आधार पर एक बड़ी टेबल को विभाजित करने की अनुमति देता है।

वाक्य - विन्यास

इसके बाद एक JOIN INDEX का सिंटेक्स है।

CREATE JOIN INDEX <index name> 
AS 
<SELECT Query> 
<Index Definition>;

उदाहरण

निम्नलिखित कर्मचारी और वेतन तालिका पर विचार करें।

CREATE SET TABLE EMPLOYEE,FALLBACK ( 
   EmployeeNo INTEGER, 
   FirstName VARCHAR(30) , 
   LastName VARCHAR(30) , 
   DOB DATE FORMAT 'YYYY-MM-DD', 
   JoinedDate DATE FORMAT 'YYYY-MM-DD', 
   DepartmentNo BYTEINT 
) 
UNIQUE PRIMARY INDEX ( EmployeeNo );

CREATE SET TABLE SALARY,FALLBACK ( 
   EmployeeNo INTEGER, 
   Gross INTEGER, 
   Deduction INTEGER, 
   NetPay INTEGER 
) 
PRIMARY INDEX ( EmployeeNo ) 
UNIQUE INDEX (EmployeeNo);

निम्नलिखित एक उदाहरण है जो कर्मचारी तालिका पर Employee_JI नामक एक जॉइन इंडेक्स बनाता है।

CREATE JOIN INDEX Employee_JI 
AS 
SELECT EmployeeNo,FirstName,LastName, 
BirthDate,JoinedDate,DepartmentNo 
FROM Employee 
PRIMARY INDEX(FirstName);

यदि उपयोगकर्ता EmployeeNo पर WHERE क्लॉज़ के साथ एक क्वेरी सबमिट करता है, तो सिस्टम अद्वितीय प्राथमिक इंडेक्स का उपयोग करके कर्मचारी तालिका को क्वेरी करेगा। यदि उपयोगकर्ता कर्मचारी_नाम का उपयोग करके कर्मचारी तालिका पर सवाल उठाता है, तो सिस्टम कर्मचारी_नाम का उपयोग करके जुड़ने वाले कर्मचारी EmpJee_JI तक पहुंच सकता है। ज्वाइन इंडेक्स की पंक्तियों को कर्मचारी_नाम कॉलम पर हैश किया गया है। यदि जॉइन इंडेक्स को परिभाषित नहीं किया गया है और कर्मचारी_नाम को द्वितीयक इंडेक्स के रूप में परिभाषित नहीं किया गया है, तो सिस्टम उन पंक्तियों को एक्सेस करने के लिए पूर्ण टेबल स्कैन करेगा जो समय लेने वाली है।

आप निम्नलिखित योजना को चला सकते हैं और अनुकूलक योजना को सत्यापित कर सकते हैं। निम्न उदाहरण में आप देख सकते हैं कि ऑप्टिमाइज़र आधार कर्मचारी तालिका के बजाय ज्वाइन इंडेक्स का उपयोग कर रहा है, जब कर्मचारी Empameee_Name कॉलम का उपयोग करके क्वेरी करता है।

EXPLAIN SELECT * FROM EMPLOYEE WHERE FirstName='Mike'; 
*** Help information returned. 8 rows. 
*** Total elapsed time was 1 second. 
Explanation 
------------------------------------------------------------------------ 
   1) First, we do a single-AMP RETRIEVE step from EMPLOYEE_JI by 
      way of the primary index "EMPLOYEE_JI.FirstName = 'Mike'" 
      with no residual conditions into Spool 1 (one-amp), which is built 
      locally on that AMP.  The size of Spool 1 is estimated with low 
      confidence to be 2 rows (232 bytes).  The estimated time for this 
      step is 0.02 seconds.
   → The contents of Spool 1 are sent back to the user as the result of 
      statement 1.  The total estimated time is 0.02 seconds.

मल्टी टेबल जॉइन इंडेक्स

एक मल्टी-टेबल जॉइन इंडेक्स एक से अधिक टेबल को मिलाकर बनाया जाता है। मल्टी-टेबल जॉइन इंडेक्स का उपयोग प्रदर्शन में सुधार के लिए अक्सर शामिल किए गए तालिकाओं के परिणाम सेट को स्टोर करने के लिए किया जा सकता है।

उदाहरण

निम्न उदाहरण कर्मचारी और वेतन सारणी में शामिल होकर एक JOIN INDEX बनाता है जिसका नाम Employee_Salary_JI है।

CREATE JOIN INDEX Employee_Salary_JI 
AS 
SELECT a.EmployeeNo,a.FirstName,a.LastName, 
a.BirthDate,a.JoinedDate,a.DepartmentNo,b.Gross,b.Deduction,b.NetPay 
FROM Employee a 
INNER JOIN Salary b 
ON(a.EmployeeNo = b.EmployeeNo) 
PRIMARY INDEX(FirstName);

जब भी बेस टेबल कर्मचारी या वेतन अपडेट किया जाता है, तो Join index Employee_Salary_JI भी स्वचालित रूप से अपडेट हो जाता है। यदि आप कर्मचारी और वेतन तालिका में शामिल होने के लिए एक क्वेरी चला रहे हैं, तो ऑप्टिमाइज़र तालिकाओं में शामिल होने के बजाय सीधे Employee_Salary_JI से डेटा तक पहुंचने का विकल्प चुन सकता है। क्वेरी पर EXPLAIN योजना का उपयोग यह सत्यापित करने के लिए किया जा सकता है कि क्या ऑप्टिमाइज़र बेस टेबल का चयन करेगा या इंडेक्स में शामिल होगा।

समुच्चय सूचकांक में शामिल हों

यदि किसी तालिका को कुछ स्तंभों पर लगातार एकत्र किया जाता है, तो प्रदर्शन में सुधार करने के लिए तालिका में कुल मिलाएं सूचकांक को परिभाषित किया जा सकता है। कुल मिलाकर इंडेक्स की एक सीमा यह है कि यह केवल SUM और COUNT फ़ंक्शन का समर्थन करता है।

उदाहरण

निम्न उदाहरण में कर्मचारी और वेतन प्रति विभाग के कुल वेतन की पहचान करने के लिए शामिल किया गया है।

CREATE JOIN INDEX Employee_Salary_JI 
AS 
SELECT a.DepartmentNo,SUM(b.NetPay) AS TotalPay 
FROM Employee a 
INNER JOIN Salary b 
ON(a.EmployeeNo = b.EmployeeNo)
GROUP BY a.DepartmentNo 
Primary Index(DepartmentNo);

दृश्य डेटाबेस ऑब्जेक्ट हैं जो क्वेरी द्वारा बनाए गए हैं। जुड़ने के माध्यम से एक ही मेज या कई तालिकाओं का उपयोग करके दृश्य बनाए जा सकते हैं। उनकी परिभाषा स्थायी रूप से डेटा शब्दकोश में संग्रहीत की जाती है, लेकिन वे डेटा की प्रतिलिपि संग्रहीत नहीं करते हैं। दृश्य के लिए डेटा गतिशील रूप से बनाया गया है।

किसी दृश्य में तालिका की पंक्तियों का सबसेट या तालिका के स्तंभों का सबसेट हो सकता है।

एक दृश्य बनाएँ

क्रिएट व्यू स्टेटमेंट का उपयोग करके व्यू बनाए जाते हैं।

वाक्य - विन्यास

व्यू बनाने के लिए सिंटैक्स निम्नलिखित है।

CREATE/REPLACE VIEW <viewname> 
AS  
<select query>;

उदाहरण

निम्नलिखित कर्मचारी तालिका पर विचार करें।

कर्मचारी संख्या पहला नाम उपनाम जन्म दिन
101 माइक जेम्स 1980/01/05
104 एलेक्स स्टुअर्ट 1984/11/06
102 रॉबर्ट विलियम्स 1983/03/05
105 रॉबर्ट जेम्स 1984/12/01
103 पीटर पॉल 1983/04/01

निम्न उदाहरण कर्मचारी तालिका पर एक दृश्य बनाता है।

CREATE VIEW Employee_View 
AS 
SELECT 
EmployeeNo, 
FirstName, 
LastName, 
FROM  
Employee;

दृश्यों का उपयोग करना

दृश्य से डेटा पुनर्प्राप्त करने के लिए आप नियमित चयन कथन का उपयोग कर सकते हैं।

उदाहरण

निम्न उदाहरण Employee_View से रिकॉर्ड प्राप्त करता है;

SELECT EmployeeNo, FirstName, LastName FROM Employee_View;

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्न आउटपुट का उत्पादन करती है।

*** Query completed. 5 rows found. 3 columns returned. 
*** Total elapsed time was 1 second.  
 EmployeeNo            FirstName                       LastName 
-----------  ------------------------------  --------------------------- 
    101                  Mike                           James 
    104                  Alex                           Stuart 
    102                  Robert                         Williams 
    105                  Robert                         James 
    103                  Peter                          Paul

दृश्यों को संशोधित करना

एक मौजूदा दृश्य को REPLACE VIEW स्टेटमेंट का उपयोग करके संशोधित किया जा सकता है।

एक दृश्य को संशोधित करने के लिए सिंटैक्स निम्नलिखित है।

REPLACE VIEW <viewname> 
AS  
<select query>;

उदाहरण

निम्न उदाहरण अतिरिक्त कॉलम जोड़ने के लिए कर्मचारी_देखें को संशोधित करता है।

REPLACE VIEW Employee_View 
AS 
SELECT 
EmployeeNo, 
FirstName, 
BirthDate,
JoinedDate 
DepartmentNo 
FROM  
Employee;

ड्रॉप व्यू

मौजूदा दृश्य को DROP VIEW स्टेटमेंट का उपयोग करके छोड़ा जा सकता है।

वाक्य - विन्यास

निम्नलिखित DROP VIEW का सिंटैक्स है।

DROP VIEW <viewname>;

उदाहरण

निम्नलिखित कर्मचारी को देखने के लिए एक उदाहरण है।

DROP VIEW Employee_View;

दृश्य के लाभ

  • दृश्य किसी तालिका की पंक्तियों या स्तंभों को प्रतिबंधित करके सुरक्षा का अतिरिक्त स्तर प्रदान करते हैं।

  • उपयोगकर्ताओं को केवल आधार तालिकाओं के बजाय विचारों तक पहुंच दी जा सकती है।

  • कई तालिकाओं के उपयोग को सरल बनाते हुए उन्हें व्यू का उपयोग करके पूर्व में शामिल किया गया।

मैक्रो SQL स्टेटमेंट्स का एक सेट है जिसे मैक्रो नाम से कॉल करके स्टोर किया जाता है। मैक्रोज़ की परिभाषा डेटा डिक्शनरी में संग्रहीत है। उपयोगकर्ताओं को केवल मैक्रो को निष्पादित करने के लिए EXEC विशेषाधिकार की आवश्यकता होती है। उपयोगकर्ताओं को मैक्रो के अंदर उपयोग की जाने वाली डेटाबेस वस्तुओं पर अलग-अलग विशेषाधिकारों की आवश्यकता नहीं है। मैक्रो स्टेटमेंट को एकल लेनदेन के रूप में निष्पादित किया जाता है। यदि मैक्रो में SQL स्टेटमेंट्स में से एक विफल हो जाता है, तो सभी स्टेटमेंट्स वापस आ जाते हैं। मैक्रोज़ मापदंडों को स्वीकार कर सकते हैं। मैक्रोज़ में DDL स्टेटमेंट हो सकते हैं, लेकिन मैक्रो में यह अंतिम स्टेटमेंट होना चाहिए।

मैक्रोज़ बनाएँ

मैक्रो क्रिएट मैक्रो स्टेटमेंट का उपयोग करके बनाया जाता है।

वाक्य - विन्यास

निम्नलिखित क्रिएट मैक्रो कमांड का सामान्य सिंटैक्स है।

CREATE MACRO <macroname> [(parameter1, parameter2,...)] ( 
   <sql statements> 
);

उदाहरण

निम्नलिखित कर्मचारी तालिका पर विचार करें।

कर्मचारी संख्या पहला नाम उपनाम जन्म दिन
101 माइक जेम्स 1980/01/05
104 एलेक्स स्टुअर्ट 1984/11/06
102 रॉबर्ट विलियम्स 1983/03/05
105 रॉबर्ट जेम्स 1984/12/01
103 पीटर पॉल 1983/04/01

निम्न उदाहरण Get_Emp नामक एक मैक्रो बनाता है। इसमें कर्मचारी तालिका से रिकॉर्ड प्राप्त करने के लिए एक चयन विवरण शामिल है।

CREATE MACRO Get_Emp AS ( 
   SELECT 
   EmployeeNo, 
   FirstName, 
   LastName 
   FROM  
   employee 
   ORDER BY EmployeeNo; 
);

कार्यकारी मैक्रों

EXEC कमांड का उपयोग करके मैक्रों को निष्पादित किया जाता है।

वाक्य - विन्यास

निम्नलिखित EXECUTE MACRO कमांड का सिंटैक्स है।

EXEC <macroname>;

उदाहरण

निम्न उदाहरण मैक्रो नाम Get_Emp को निष्पादित करता है; जब निम्न आदेश निष्पादित किया जाता है, तो यह कर्मचारी तालिका से सभी रिकॉर्ड पुनर्प्राप्त करता है।

EXEC Get_Emp; 
*** Query completed. 5 rows found. 3 columns returned. 
*** Total elapsed time was 1 second.  
EmployeeNo             FirstName                      LastName 
-----------  ------------------------------  --------------------------- 
   101                  Mike                          James 
   102                  Robert                        Williams 
   103                  Peter                         Paul 
   104                  Alex                          Stuart 
   105                  Robert                        James

परिमाणित मैक्रोज़

टेराडाटा मैक्रोज़ मापदंडों को स्वीकार कर सकते हैं। एक मैक्रो के भीतर, इन मापदंडों को संदर्भित किया जाता है; (अर्धविराम)।

निम्नलिखित एक मैक्रो का एक उदाहरण है जो मापदंडों को स्वीकार करता है।

CREATE MACRO Get_Emp_Salary(EmployeeNo INTEGER) AS ( 
   SELECT 
   EmployeeNo, 
   NetPay 
   FROM  
   Salary 
   WHERE EmployeeNo = :EmployeeNo; 
);

निष्पादन योग्य मैक्रोज़

EXEC कमांड का उपयोग करके मैक्रों को निष्पादित किया जाता है। मैक्रोज़ को निष्पादित करने के लिए आपको EXEC विशेषाधिकार की आवश्यकता है।

वाक्य - विन्यास

निम्नलिखित EXECUTE MACRO स्टेटमेंट का सिंटैक्स है।

EXEC <macroname>(value);

उदाहरण

निम्न उदाहरण मैक्रो नाम Get_Emp को निष्पादित करता है; यह कर्मचारी को पैरामीटर के रूप में स्वीकार नहीं करता है और उस कर्मचारी के लिए कर्मचारी तालिका से रिकॉर्ड निकालता है।

EXEC Get_Emp_Salary(101); 
*** Query completed. One row found. 2 columns returned. 
*** Total elapsed time was 1 second.
 
EmployeeNo      NetPay 
-----------  ------------ 
   101           36000

संग्रहीत कार्यविधि में SQL कथन और प्रक्रियात्मक कथनों का एक सेट होता है। उनमें केवल प्रक्रियात्मक कथन हो सकते हैं। संग्रहीत कार्यविधि की परिभाषा डेटाबेस में संग्रहीत की जाती है और पैरामीटर डेटा डिक्शनरी टेबल में संग्रहीत किए जाते हैं।

लाभ

  • संग्रहीत कार्यविधियाँ क्लाइंट और सर्वर के बीच नेटवर्क लोड को कम करती हैं।

  • डेटा को सीधे एक्सेस करने के बजाय संग्रहीत प्रक्रियाओं के माध्यम से एक्सेस करने के बाद से बेहतर सुरक्षा प्रदान करता है।

  • व्यापार तर्क का परीक्षण और सर्वर में संग्रहीत होने के बाद से बेहतर रखरखाव देता है।

प्रक्रिया बनाना

संग्रहीत कार्यविधियाँ क्रिएट प्रक्रिया कथन का उपयोग कर बनाई गई हैं।

वाक्य - विन्यास

निम्नलिखित निर्माण प्रक्रिया विवरण का सामान्य वाक्यविन्यास है।

CREATE PROCEDURE <procedurename> ( [parameter 1 data type, parameter 2 data type..] ) 
BEGIN 
   <SQL or SPL statements>; 
END;

उदाहरण

निम्नलिखित वेतन तालिका पर विचार करें।

कर्मचारी संख्या कुल कटौती कुल भुगतान
101 40,000 4000 36,000
102 80,000 6000 74,000
103 90,000 7000 83,000
104 75,000 5000 70,000

निम्न उदाहरण मानों को स्वीकार करने और वेतन तालिका में सम्मिलित करने के लिए InsertSalary नामक एक संग्रहीत कार्यविधि बनाता है।

CREATE PROCEDURE InsertSalary ( 
   IN in_EmployeeNo INTEGER, IN in_Gross INTEGER, 
   IN in_Deduction INTEGER, IN in_NetPay INTEGER 
) 
BEGIN 
   INSERT INTO Salary ( 
      EmployeeNo, 
      Gross, 
      Deduction, 
      NetPay 
   ) 
   VALUES ( 
      :in_EmployeeNo, 
      :in_Gross, 
      :in_Deduction, 
      :in_NetPay 
   ); 
END;

निष्पादन की प्रक्रिया

कॉल प्रक्रिया का उपयोग करके संग्रहीत कार्यविधियाँ निष्पादित की जाती हैं।

वाक्य - विन्यास

निम्नलिखित कॉल स्टेटमेंट का जेनेरिक सिंटैक्स है।

CALL <procedure name> [(parameter values)];

उदाहरण

निम्न उदाहरण संग्रहित प्रक्रिया InsertSalary और आवेषण रिकॉर्ड को वेतन तालिका में कॉल करता है।

CALL InsertSalary(105,20000,2000,18000);

एक बार उपरोक्त क्वेरी निष्पादित होने के बाद, यह निम्नलिखित आउटपुट का उत्पादन करता है और आप वेतन तालिका में सम्मिलित पंक्ति देख सकते हैं।

कर्मचारी संख्या कुल कटौती कुल भुगतान
101 40,000 4000 36,000
102 80,000 6000 74,000
103 90,000 7000 83,000
104 75,000 5000 70,000
105 20,000 2,000 18,000

यह अध्याय Teradata में उपलब्ध विभिन्न JOIN रणनीतियों पर चर्चा करता है।

विधियों में शामिल हों

Teradata में शामिल होने के संचालन के लिए अलग-अलग तरीकों का उपयोग करता है। आमतौर पर इस्तेमाल किए जाने वाले कुछ तरीकों में शामिल हैं -

  • मिलाना
  • सम्मिलित हों
  • उत्पाद शामिल हों

मिलाना

मर्ज ज्वाइन विधि तब होती है जब ज्वाइनिंग समानता की स्थिति पर आधारित होती है। मर्ज ज्वाइन की आवश्यकता है कि पंक्तियाँ एक ही AMP पर हों। पंक्तियों को उनकी पंक्ति हैश के आधार पर जोड़ा जाता है। मर्ज ज्वाइन पंक्तियों को समान एएमपी में लाने के लिए विभिन्न जॉइन स्ट्रेटजी का उपयोग करता है।

रणनीति # 1

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

निम्नलिखित कर्मचारी और वेतन तालिका पर विचार करें।

CREATE SET TABLE EMPLOYEE,FALLBACK ( 
   EmployeeNo INTEGER, 
   FirstName VARCHAR(30) , 
   LastName VARCHAR(30) , 
   DOB DATE FORMAT 'YYYY-MM-DD', 
   JoinedDate DATE FORMAT 'YYYY-MM-DD', 
   DepartmentNo BYTEINT 
) 
UNIQUE PRIMARY INDEX ( EmployeeNo );
CREATE SET TABLE Salary ( 
   EmployeeNo INTEGER, 
   Gross INTEGER,  
   Deduction INTEGER, 
   NetPay INTEGER 
) 
UNIQUE PRIMARY INDEX(EmployeeNo);

जब इन दो तालिकाओं को EmployeeNo कॉलम में शामिल किया जाता है, तो कोई पुनर्वितरण नहीं होता है क्योंकि EmployeeNo दोनों तालिकाओं का प्राथमिक सूचकांक है, जो जुड़ रहा है।

रणनीति # 2

निम्नलिखित कर्मचारी और विभाग की तालिकाओं पर विचार करें।

CREATE SET TABLE EMPLOYEE,FALLBACK (
   EmployeeNo INTEGER, 
   FirstName VARCHAR(30) , 
   LastName VARCHAR(30) , 
   DOB DATE FORMAT 'YYYY-MM-DD', 
   JoinedDate DATE FORMAT 'YYYY-MM-DD', 
   DepartmentNo BYTEINT 
) 
UNIQUE PRIMARY INDEX ( EmployeeNo );
CREATE SET TABLE DEPARTMENT,FALLBACK ( 
   DepartmentNo BYTEINT, 
   DepartmentName CHAR(15) 
) 
UNIQUE PRIMARY INDEX ( DepartmentNo );

यदि इन दो तालिकाओं को DeparmentNo कॉलम में शामिल किया जाता है, तो पंक्तियों को पुनर्वितरित करने की आवश्यकता होती है क्योंकि DepartmentNo एक तालिका में एक प्राथमिक सूचकांक और दूसरी तालिका में गैर-प्राथमिक सूचकांक है। इस परिदृश्य में, पंक्तियों को जोड़ना एक ही AMP पर नहीं हो सकता है। ऐसे मामले में, Teradata विभागीय स्तंभ पर कर्मचारी तालिका को पुनर्वितरित कर सकता है।

रणनीति # 3

उपर्युक्त कर्मचारी और विभाग की तालिकाओं के लिए, Teradata विभाग की तालिका को सभी AMP पर डुप्लिकेट कर सकता है, यदि विभाग तालिका का आकार छोटा है।

सम्मिलित हों

नेस्टेड जॉइन सभी AMPs का उपयोग नहीं करता है। नेस्टेड जॉइन के लिए जगह लेने के लिए, किसी एक शर्त को एक टेबल के यूनिक प्राइमरी इंडेक्स पर समानता होना चाहिए और फिर इस कॉलम को दूसरे टेबल पर किसी भी इंडेक्स में शामिल करना चाहिए।

इस परिदृश्य में, सिस्टम एक तालिका के अनन्य प्राथमिक अनुक्रमणिका का उपयोग करके एक पंक्ति प्राप्त करेगा और दूसरी पंक्ति से मिलान रिकॉर्ड लाने के लिए उस पंक्ति हैश का उपयोग करेगा। नेस्टेड जॉइन सभी जॉइन मेथड्स में से सबसे कुशल है।

उत्पाद शामिल हों

प्रोडक्ट जॉइन एक टेबल से प्रत्येक क्वालिफाइंग पंक्ति की तुलना दूसरे टेबल से प्रत्येक क्वालिफाइंग पंक्ति से करता है। निम्नलिखित कुछ कारकों के कारण उत्पाद जुड़ सकते हैं -

  • जहां हालत गायब है।
  • ज्वाइन की गई शर्त समानता की स्थिति पर आधारित नहीं है।
  • टेबल अलायस सही नहीं है।
  • एकाधिक स्थितियों में शामिल हों।

विभाजन प्राथमिक सूचकांक (PPI) एक अनुक्रमण तंत्र है जो कुछ प्रश्नों के प्रदर्शन को बेहतर बनाने में उपयोगी है। जब पंक्तियों को एक तालिका में डाला जाता है, तो उन्हें एएमपी में संग्रहीत किया जाता है और उनकी पंक्ति हैश क्रम द्वारा व्यवस्थित की जाती है। जब एक टेबल को पीपीआई के साथ परिभाषित किया जाता है, तो पंक्तियों को उनके विभाजन संख्या द्वारा क्रमबद्ध किया जाता है। प्रत्येक विभाजन के भीतर, उनकी पंक्ति हैश द्वारा व्यवस्थित की जाती है। पंक्तियों को परिभाषित विभाजन अभिव्यक्ति के आधार पर एक विभाजन को सौंपा गया है।

लाभ

  • कुछ प्रश्नों के लिए पूर्ण तालिका स्कैन से बचें।

  • अतिरिक्त शारीरिक संरचना और अतिरिक्त I / O रखरखाव की आवश्यकता वाले माध्यमिक सूचकांक के उपयोग से बचें।

  • एक बड़ी तालिका के सबसेट को जल्दी से एक्सेस करें।

  • पुराने डेटा को जल्दी से ड्रॉप करें और नया डेटा जोड़ें।

उदाहरण

ऑर्डरऑनो पर प्राथमिक सूचकांक के साथ निम्नलिखित आदेश तालिका पर विचार करें।

जमा मत करो आदेश संख्या आदेश की तारीख कुल आदेश
101 7501 2015/10/01 900
101 7502 2015/10/02 1,200
102 7503 2015/10/02 3000
102 7504 2015/10/03 2,454
101 7505 2015/10/03 1201
103 7506 2015/10/04 2,454
101 7507 2015/10/05 1201
101 7508 2015/10/05 1201

मान लें कि रिकॉर्ड एएमपी के बीच वितरित किए गए हैं जैसा कि निम्नलिखित तालिकाओं में दिखाया गया है। रिकॉर्ड किए गए एएमपी में संग्रहीत किए जाते हैं, उनकी पंक्ति हैश के आधार पर सॉर्ट की जाती हैं।

एएमपी 1

RowHash आदेश संख्या आदेश की तारीख
1 7505 2015/10/03
2 7504 2015/10/03
3 7501 2015/10/01
4 7508 2015/10/05

एएमपी 2

RowHash आदेश संख्या आदेश की तारीख
1 7507 2015/10/05
2 7502 2015/10/02
3 7506 2015/10/04
4 7503 2015/10/02

यदि आप किसी विशेष तिथि के आदेश निकालने के लिए क्वेरी चलाते हैं, तो ऑप्टिमाइज़र पूर्ण तालिका स्कैन का उपयोग करने का विकल्प चुन सकता है, तो एएमपी के भीतर सभी रिकॉर्ड एक्सेस किए जा सकते हैं। इससे बचने के लिए, आप ऑर्डर की तारीख को विभाजन प्राथमिक सूचकांक के रूप में परिभाषित कर सकते हैं। जब पंक्तियों को ऑर्डर टेबल में डाला जाता है, तो वे ऑर्डर की तारीख से विभाजित होते हैं। प्रत्येक विभाजन के भीतर उन्हें उनकी पंक्ति हैश द्वारा आदेश दिया जाएगा।

निम्न डेटा दिखाता है कि रिकॉर्ड को एएमपी में कैसे संग्रहीत किया जाएगा, यदि वे ऑर्डर दिनांक द्वारा विभाजित किए गए हैं। यदि ऑर्डर दिनांक द्वारा रिकॉर्ड तक पहुंचने के लिए एक क्वेरी चलाई जाती है, तो केवल उस विशेष ऑर्डर के रिकॉर्ड वाले विभाजन को एक्सेस किया जाएगा।

एएमपी 1

PARTITION RowHash आदेश संख्या आदेश की तारीख
0 3 7501 2015/10/01
1 1 7505 2015/10/03
1 2 7504 2015/10/03
2 4 7508 2015/10/05

एएमपी 2

PARTITION RowHash आदेश संख्या आदेश की तारीख
0 2 7502 2015/10/02
0 4 7503 2015/10/02
1 3 7506 2015/10/04
2 1 7507 2015/10/05

विभाजन प्राथमिक सूचकांक के साथ तालिका बनाने के लिए एक उदाहरण निम्नलिखित है। विभाजन द्वारा खंड विभाजन को परिभाषित करने के लिए उपयोग किया जाता है।

CREATE SET TABLE Orders (
   StoreNo SMALLINT, 
   OrderNo INTEGER, 
   OrderDate DATE FORMAT 'YYYY-MM-DD', 
   OrderTotal INTEGER 
) 
PRIMARY INDEX(OrderNo) 
PARTITION BY RANGE_N  (
   OrderDate BETWEEN DATE '2010-01-01' AND '2016-12-31' EACH INTERVAL '1' DAY
);

उपरोक्त उदाहरण में, तालिका को ऑर्डरडेट कॉलम द्वारा विभाजित किया गया है। प्रत्येक दिन के लिए एक अलग विभाजन होगा।

OLAP फ़ंक्शन कुल कार्यों के समान हैं सिवाय इसके कि कुल फ़ंक्शन केवल एक मान लौटाएंगे, जबकि OLAP फ़ंक्शन एग्रीगेट के अलावा व्यक्तिगत पंक्तियों को प्रदान करेगा।

वाक्य - विन्यास

निम्नलिखित OLAP फ़ंक्शन का सामान्य सिंटैक्स है।

<aggregate function> OVER  
([PARTITION BY] [ORDER BY columnname][ROWS BETWEEN 
UNBOUDED PRECEDING AND UNBOUNDED FOLLOWING)

एकत्रीकरण कार्य SUM, COUNT, MAX, MIN, AVG हो सकते हैं।

उदाहरण

निम्नलिखित वेतन तालिका पर विचार करें।

कर्मचारी संख्या कुल कटौती कुल भुगतान
101 40,000 4000 36,000
102 80,000 6000 74,000
103 90,000 7000 83,000
104 75,000 5000 70,000

निम्नलिखित वेतन का योग या वेतन तालिका पर कुल नेटपे चलाने का एक उदाहरण है। रिकॉर्ड EmployeeNo द्वारा सॉर्ट किए जाते हैं और संचयी योग की गणना नेटपे कॉलम पर की जाती है।

SELECT  
EmployeeNo, NetPay, 
SUM(Netpay) OVER(ORDER BY EmployeeNo ROWS  
UNBOUNDED PRECEDING) as TotalSalary 
FROM Salary;

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्न आउटपुट का उत्पादन करती है।

EmployeeNo     NetPay     TotalSalary 
-----------  -----------  ----------- 
   101         36000        36000 
   102         74000        110000 
   103         83000        193000 
   104         70000        263000 
   105         18000        281000

पद

RANK फ़ंक्शन प्रदान किए गए कॉलम के आधार पर रिकॉर्ड का आदेश देता है। RANK फ़ंक्शन रैंक के आधार पर लौटाए गए रिकॉर्ड की संख्या को भी फ़िल्टर कर सकता है।

वाक्य - विन्यास

RANK फ़ंक्शन का उपयोग करने के लिए जेनेरिक सिंटैक्स निम्नलिखित है।

RANK() OVER 
([PARTITION BY columnnlist] [ORDER BY columnlist][DESC|ASC])

उदाहरण

निम्नलिखित कर्मचारी तालिका पर विचार करें।

कर्मचारी संख्या पहला नाम उपनाम JoinedDate DepartmentID जन्म दिन
101 माइक जेम्स 2005/03/27 1 1980/01/05
102 रॉबर्ट विलियम्स 2007/04/25 2 1983/03/05
103 पीटर पॉल 2007/03/21 2 1983/04/01
104 एलेक्स स्टुअर्ट 2008/02/01 2 1984/11/06
105 रॉबर्ट जेम्स 2008/01/04 3 1984/12/01

क्वेरी के बाद कर्मचारी तालिका में सम्मिलित तिथि के रिकॉर्ड का आदेश देता है और सम्मिलित तिथि पर रैंकिंग प्रदान करता है।

SELECT EmployeeNo, JoinedDate,RANK() 
OVER(ORDER BY JoinedDate) as Seniority 
FROM Employee;

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्न आउटपुट का उत्पादन करती है।

EmployeeNo   JoinedDate   Seniority 
-----------  ----------  ----------- 
   101       2005-03-27       1 
   103       2007-03-21       2 
   102       2007-04-25       3 
   105       2008-01-04       4 
   104       2008-02-01       5

विभाजन खंड खंड द्वारा डेटा स्तंभ में परिभाषित खंड द्वारा समूहों और प्रत्येक समूह के भीतर OLAP कार्य करता है। निम्नलिखित क्वेरी का एक उदाहरण है जो खंड द्वारा खंड का उपयोग करता है।

SELECT EmployeeNo, JoinedDate,RANK() 
OVER(PARTITION BY DeparmentNo ORDER BY JoinedDate) as Seniority 
FROM Employee;

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्न आउटपुट का उत्पादन करती है। आप देख सकते हैं कि रैंक प्रत्येक विभाग के लिए रीसेट है।

EmployeeNo  DepartmentNo  JoinedDate   Seniority 
-----------  ------------  ----------  ----------- 

    101           1        2005-03-27       1 
    103           2        2007-03-21       1 
    102           2        2007-04-25       2 
    104           2        2008-02-01       3 
    105           3        2008-01-04       1

यह अध्याय टेराडाटा में डेटा सुरक्षा के लिए उपलब्ध सुविधाओं पर चर्चा करता है।

क्षणिक पत्रिका

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

मैदान छोड़ना

फ़ॉलबैक किसी अन्य एएमपी पर तालिका की पंक्तियों की दूसरी कॉपी को फ़ॉलबैक एएमपी कहकर तालिका डेटा की सुरक्षा करता है। यदि एक एएमपी विफल रहता है, तो फ़ॉलबैक पंक्तियों तक पहुँचा जाता है। इसके साथ, भले ही एक एएमपी विफल हो, डेटा अभी भी एबैकबैक एएमपी के माध्यम से उपलब्ध है। फ़ॉलबैक विकल्प का उपयोग टेबल निर्माण या टेबल निर्माण के बाद किया जा सकता है। फ़ॉलबैक यह सुनिश्चित करता है कि एएमपी विफलता से डेटा की सुरक्षा के लिए तालिका की पंक्तियों की दूसरी प्रति हमेशा दूसरे एएमपी में संग्रहीत की जाती है। हालाँकि, फ़ॉलबैक दो बार स्टोरेज और I / O को इन्सर्ट / डिलीट / अपडेट के लिए अधिग्रहित करता है।

निम्नलिखित आरेख से पता चलता है कि किसी अन्य AMP में पंक्तियों की फ़ॉलबैक प्रतिलिपि कैसे संग्रहीत की जाती है।

डाउन एएमपी रिकवरी जर्नल

डाउन एएमपी रिकवरी जर्नल तब सक्रिय होता है जब एएमपी विफल हो जाता है और टेबल की बैकबैक संरक्षित होती है। यह पत्रिका विफल एएमपी के डेटा में सभी परिवर्तनों का ट्रैक रखती है। क्लस्टर में शेष एएमपी पर पत्रिका सक्रिय है। यह एक स्वचालित प्रक्रिया है और इसे अक्षम नहीं किया जा सकता है। एक बार असफल एएमपी लाइव है तो डाउन एएमपी रिकवरी जर्नल से डेटा एएमपी के साथ सिंक्रनाइज़ किया जाता है। यह हो जाने के बाद, पत्रिका को छोड़ दिया जाता है।

क्लिक्स

क्लोड एक तंत्र है जिसका उपयोग टेराडाटा द्वारा नोड विफलताओं से डेटा की रक्षा के लिए किया जाता है। एक क्लिपर कुछ भी नहीं है, लेकिन Teradata नोड्स का एक सेट है जो डिस्क एरे का एक आम सेट साझा करता है। जब एक नोड विफल हो जाता है, तो विफल नोड से vprocs क्लिक में अन्य नोड्स में चले जाएंगे और उनकी डिस्क किरणों तक पहुंच जारी रखेंगे।

हॉट स्टैंडबाय नोड

हॉट स्टैंडबाय नोड एक नोड है जो उत्पादन वातावरण में भाग नहीं लेता है। यदि एक नोड विफल रहता है, तो विफल नोड्स से vprocs गर्म स्टैंडबाय नोड में चले जाएंगे। एक बार असफल नोड बरामद होने के बाद यह हॉट स्टैंडबाय नोड बन जाता है। नोड विफलता के मामले में प्रदर्शन को बनाए रखने के लिए हॉट स्टैंडबाय नोड्स का उपयोग किया जाता है।

छापा

इंडिपेंडेंट डिस्क (RAID) का निरर्थक ऐरे डिस्क फेल्योर से डेटा को सुरक्षित रखने के लिए उपयोग किया जाने वाला एक तंत्र है। डिस्क सरणी में डिस्क का एक सेट होता है जिसे एक तार्किक इकाई के रूप में वर्गीकृत किया जाता है। यह इकाई उपयोगकर्ता के लिए एक एकल इकाई की तरह दिख सकती है लेकिन वे कई डिस्क में फैली हो सकती हैं।

टेराडाटा में आमतौर पर RAID 1 का उपयोग किया जाता है। RAID 1 में, प्रत्येक डिस्क एक दर्पण डिस्क के साथ जुड़ा हुआ है। प्राथमिक डिस्क में डेटा में कोई भी परिवर्तन दर्पण प्रति में भी परिलक्षित होता है। यदि प्राथमिक डिस्क विफल हो जाती है, तो दर्पण डिस्क से डेटा तक पहुँचा जा सकता है।

इस अध्याय ने टेराडाटा में उपयोगकर्ता प्रबंधन की विभिन्न रणनीतियों पर चर्चा की।

उपयोगकर्ताओं

एक उपयोगकर्ता क्रिएट USER कमांड का उपयोग करके बनाया गया है। Teradata में, एक उपयोगकर्ता भी एक डेटाबेस के समान है। वे दोनों को स्थान निर्दिष्ट किया जा सकता है और डेटाबेस ऑब्जेक्ट्स को छोड़ सकते हैं सिवाय इसके कि उपयोगकर्ता को एक पासवर्ड सौंपा जाए।

वाक्य - विन्यास

निम्नलिखित निर्माता के लिए वाक्य रचना है।

CREATE USER username 
AS  
[PERMANENT|PERM] = n BYTES 
PASSWORD = password 
TEMPORARY = n BYTES 
SPOOL = n BYTES;

उपयोगकर्ता बनाते समय, उपयोगकर्ता नाम, स्थायी स्थान और पासवर्ड के लिए मान अनिवार्य है। अन्य क्षेत्र वैकल्पिक हैं।

उदाहरण

निम्नलिखित उपयोगकर्ता TD01 बनाने के लिए एक उदाहरण है।

CREATE USER TD01 
AS  
PERMANENT = 1000000 BYTES 
PASSWORD = ABC$124 
TEMPORARY = 1000000 BYTES 
SPOOL = 1000000 BYTES;

हिसाब किताब

एक नया उपयोगकर्ता बनाते समय, उपयोगकर्ता को एक खाते को सौंपा जा सकता है। अकाउंट को असाइन करने के लिए CREATE USER में ACCOUNT विकल्प का उपयोग किया जाता है। एक उपयोगकर्ता को कई खातों को सौंपा जा सकता है।

वाक्य - विन्यास

खाता विकल्प के साथ क्रिएट USER का सिंटैक्स निम्नलिखित है।

CREATE USER username 
PERM = n BYTES 
PASSWORD = password 
ACCOUNT = accountid

उदाहरण

निम्न उदाहरण उपयोगकर्ता TD02 बनाता है और खाता को IT और व्यवस्थापन के रूप में निर्दिष्ट करता है।

CREATE USER TD02 
AS  
PERMANENT = 1000000 BYTES 
PASSWORD = abc$123 
TEMPORARY = 1000000 BYTES 
SPOOL = 1000000 BYTES 
ACCOUNT = (‘IT’,’Admin’);

उपयोगकर्ता Teradata प्रणाली में लॉग इन करते समय या SET सत्र आदेश का उपयोग करके सिस्टम में लॉग इन करने के बाद खाता आईडी निर्दिष्ट कर सकता है।

.LOGON username, passowrd,accountid 
OR 
SET SESSION ACCOUNT = accountid

अनुदान प्रदान करता है

उपयोगकर्ता या डेटाबेस के लिए डेटाबेस ऑब्जेक्ट पर एक या अधिक विशेषाधिकार निर्दिष्ट करने के लिए GRANT कमांड का उपयोग किया जाता है।

वाक्य - विन्यास

निम्नलिखित GRANT कमांड का सिंटैक्स है।

GRANT privileges ON objectname TO username;

विशेषाधिकार INSERT, SELECT, UPDATE, REFERENCES हो सकते हैं।

उदाहरण

निम्नलिखित GRANT कथन का एक उदाहरण है।

GRANT SELECT,INSERT,UPDATE ON Employee TO TD01;

विशेषाधिकार रद्द करें

REVOKE कमांड उपयोगकर्ताओं या डेटाबेस से विशेषाधिकारों को हटा देती है। REVOKE कमांड केवल स्पष्ट विशेषाधिकार हटा सकती है।

वाक्य - विन्यास

निम्नलिखित REVOKE कमांड के लिए मूल सिंटैक्स है।

REVOKE [ALL|privileges] ON objectname FROM username;

उदाहरण

निम्नलिखित REVOKE कमांड का एक उदाहरण है।

REVOKE INSERT,SELECT ON Employee FROM TD01;

यह अध्याय टेराडाटा में प्रदर्शन ट्यूनिंग की प्रक्रिया पर चर्चा करता है।

समझाना

प्रदर्शन ट्यूनिंग में पहला कदम आपकी क्वेरी पर EXPLAIN का उपयोग है। EXPLAIN योजना यह विवरण देती है कि ऑप्टिमाइज़र आपकी क्वेरी को कैसे निष्पादित करेगा। व्याख्या योजना में, विश्वास स्तर जैसे कीवर्ड की जाँच करें, उपयोग की गई रणनीति, स्पूल फ़ाइल का आकार, पुनर्वितरण, इत्यादि सम्मिलित करें।

सांख्यिकी लीजिए

ऑप्टिमाइज़र प्रभावी निष्पादन रणनीति के साथ आने के लिए डेटा जनसांख्यिकी का उपयोग करता है। COLLECT STATISTICS कमांड का उपयोग तालिका के डेटा जनसांख्यिकी को इकट्ठा करने के लिए किया जाता है। सुनिश्चित करें कि स्तंभों पर एकत्रित आँकड़े अद्यतित हैं।

  • उन कॉलम पर आंकड़े एकत्र करें, जिनका उपयोग WHERE क्लॉज और जॉइनिंग कंडीशन में उपयोग किए गए कॉलम पर किया जाता है।

  • यूनिक प्राइमरी इंडेक्स कॉलम पर आंकड़े एकत्र करें।

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

  • ज्वाइन इंडेक्स पर आंकड़े इकट्ठा करें हालांकि बेस टेबल पर आंकड़े एकत्र किए गए हैं।

  • विभाजन कॉलम पर आंकड़े एकत्र करें।

जानकारी का प्रकार

सुनिश्चित करें कि उचित डेटा प्रकार का उपयोग किया जाता है। यह आवश्यकता से अधिक भंडारण के उपयोग से बच जाएगा।

परिवर्तन

सुनिश्चित करें कि जुड़ने की स्थिति में उपयोग किए जाने वाले स्तंभों के डेटा प्रकार स्पष्ट डेटा रूपांतरणों से बचने के लिए संगत हैं।

तरह

जब तक आवश्यक न हो तब अनावश्यक आदेश निकालें।

स्पूल स्पेस इश्यू

यदि उस उपयोगकर्ता के लिए AMP स्पूल स्थान सीमा से अधिक है तो स्पूल स्पेस एरर उत्पन्न होता है। व्याख्या योजना को सत्यापित करें और उस कदम की पहचान करें जो अधिक स्पूल स्थान का उपभोग करता है। इन मध्यवर्ती प्रश्नों को विभाजित किया जा सकता है और अस्थायी तालिकाओं के निर्माण के लिए अलग से रखा जा सकता है।

प्राथमिक सूचकांक

सुनिश्चित करें कि प्राथमिक सूचकांक तालिका के लिए सही ढंग से परिभाषित है। प्राथमिक इंडेक्स कॉलम को समान रूप से डेटा वितरित करना चाहिए और डेटा को एक्सेस करने के लिए अक्सर उपयोग किया जाना चाहिए।

सेट तालिका

यदि आप एक सेट तालिका को परिभाषित करते हैं, तो ऑप्टिमाइज़र यह जांच करेगा कि क्या रिकॉर्ड प्रत्येक और प्रत्येक रिकॉर्ड के लिए डुप्लिकेट है। डुप्लिकेट चेक की स्थिति को दूर करने के लिए, आप तालिका के लिए विशिष्ट द्वितीयक सूचकांक को परिभाषित कर सकते हैं।

बड़ी तालिका पर अद्यतन

बड़ी तालिका को अपडेट करने में समय लगेगा। तालिका को अपडेट करने के बजाय, आप रिकॉर्ड को हटा सकते हैं और संशोधित पंक्तियों के साथ रिकॉर्ड डाल सकते हैं।

अस्थाई टेबलों को गिराना

अस्थायी तालिकाओं (स्टेजिंग टेबल) और वाष्पशील को गिरा दें, यदि उनकी आवश्यकता नहीं है। यह स्थायी स्थान और स्पूल स्पेस को मुक्त करेगा।

एकाधिक तालिका

यदि आप सुनिश्चित हैं कि इनपुट रिकॉर्ड में डुप्लिकेट रिकॉर्ड नहीं होंगे, तो आप सेट तालिका द्वारा उपयोग की गई डुप्लिकेट पंक्ति की जाँच से बचने के लिए लक्ष्य तालिका को MULTISET तालिका के रूप में परिभाषित कर सकते हैं।

फास्टलैड उपयोगिता का उपयोग डेटा को खाली तालिकाओं में लोड करने के लिए किया जाता है। चूंकि यह क्षणिक पत्रिकाओं का उपयोग नहीं करता है, इसलिए डेटा को जल्दी से लोड किया जा सकता है। यह डुप्लिकेट पंक्तियों को लोड नहीं करता है, भले ही लक्ष्य तालिका एक MULTISET तालिका हो।

परिसीमन

लक्ष्य तालिका में द्वितीयक सूचकांक नहीं होना चाहिए, सूचकांक और विदेशी कुंजी संदर्भ में शामिल होना चाहिए।

फास्टलाड कैसे काम करता है

फास्टलैड को दो चरणों में निष्पादित किया जाता है।

चरण 1

  • पार्सिंग इंजन इनपुट फ़ाइल से रिकॉर्ड पढ़ते हैं और प्रत्येक एएमपी को एक ब्लॉक भेजते हैं।

  • प्रत्येक एएमपी अभिलेखों के ब्लॉक संग्रहीत करता है।

  • फिर AMPs ने प्रत्येक रिकॉर्ड को हैश में किया और उन्हें सही AMP पर पुनर्वितरित किया।

  • चरण 1 के अंत में, प्रत्येक AMP की पंक्तियाँ होती हैं लेकिन वे पंक्ति हैश अनुक्रम में नहीं होती हैं।

2 चरण

  • चरण 2 तब शुरू होता है जब FastLoad को END LOADING स्टेटमेंट प्राप्त होता है।

  • प्रत्येक एएमपी पंक्ति हैश पर रिकॉर्ड को सॉर्ट करता है और उन्हें डिस्क पर लिखता है।

  • लक्ष्य तालिका पर ताले जारी कर दिए जाते हैं और त्रुटि तालिकाएँ गिरा दी जाती हैं।

उदाहरण

निम्नलिखित रिकॉर्ड के साथ एक टेक्स्ट फ़ाइल बनाएं और फ़ाइल को कर्मचारी के रूप में नाम दें।

101,Mike,James,1980-01-05,2010-03-01,1  
102,Robert,Williams,1983-03-05,2010-09-01,1 
103,Peter,Paul,1983-04-01,2009-02-12,2 
104,Alex,Stuart,1984-11-06,2014-01-01,2 
105,Robert,James,1984-12-01,2015-03-09,3

उपरोक्त फ़ाइल को Employee_Stg तालिका में लोड करने के लिए एक नमूना FastLoad स्क्रिप्ट निम्नलिखित है।

LOGON 192.168.1.102/dbc,dbc;  
   DATABASE tduser;  
   BEGIN LOADING tduser.Employee_Stg  
      ERRORFILES Employee_ET, Employee_UV  
      CHECKPOINT 10;  
      SET RECORD VARTEXT ",";  
      DEFINE in_EmployeeNo (VARCHAR(10)), 
         in_FirstName (VARCHAR(30)), 
         in_LastName (VARCHAR(30)), 
         in_BirthDate (VARCHAR(10)), 
         in_JoinedDate (VARCHAR(10)), 
         in_DepartmentNo (VARCHAR(02)), 
         FILE = employee.txt;
      INSERT INTO Employee_Stg (
         EmployeeNo,
         FirstName,
         LastName,
         BirthDate,
         JoinedDate, 
         DepartmentNo
      ) 
      VALUES (  
         :in_EmployeeNo, 
         :in_FirstName, 
         :in_LastName, 
         :in_BirthDate (FORMAT 'YYYY-MM-DD'), 
         :in_JoinedDate (FORMAT 'YYYY-MM-DD'),
         :in_DepartmentNo
      ); 
   END LOADING;  
LOGOFF;

फास्टलाड स्क्रिप्ट का निष्पादन

एक बार जब इनपुट फ़ाइल कर्मचारी। Txt बनाया जाता है और FastLoad स्क्रिप्ट को EmployeeLoad.fl नाम दिया जाता है, तो आप UNIX और Windows में निम्न कमांड का उपयोग करके FastLoad स्क्रिप्ट चला सकते हैं।

FastLoad < EmployeeLoad.fl;

एक बार उपरोक्त कमांड निष्पादित होने के बाद, FastLoad स्क्रिप्ट लॉग को चलाएगी और उत्पादन करेगी। लॉग में, आप FastLoad और स्थिति कोड द्वारा संसाधित रिकॉर्ड की संख्या देख सकते हैं।

**** 03:19:14 END LOADING COMPLETE 
   Total Records Read              =  5 
   Total Error Table 1             =  0  ---- Table has been dropped 
   Total Error Table 2             =  0  ---- Table has been dropped 
   Total Inserts Applied           =  5 
   Total Duplicate Rows            =  0 
   Start:   Fri Jan  8 03:19:13 2016 
   End  :   Fri Jan  8 03:19:14 2016 
**** 03:19:14 Application Phase statistics: 
              Elapsed time: 00:00:01 (in hh:mm:ss) 
0008  LOGOFF; 
**** 03:19:15 Logging off all sessions

FastLoad शर्तें

निम्नलिखित FastLoad स्क्रिप्ट में उपयोग किए जाने वाले सामान्य शब्दों की सूची है।

  • LOGON - टेराडाटा में प्रवेश करता है और एक या अधिक सत्र आरंभ करता है।

  • DATABASE - डिफ़ॉल्ट डेटाबेस सेट करता है।

  • BEGIN LOADING - लोड की जाने वाली तालिका की पहचान करता है।

  • ERRORFILES - 2 त्रुटि तालिकाओं की पहचान करता है जिन्हें बनाने / अद्यतन करने की आवश्यकता होती है।

  • CHECKPOINT - चेकपॉइंट लेने पर परिभाषित करता है।

  • SET RECORD - निर्दिष्ट करता है कि क्या इनपुट फ़ाइल प्रारूप स्वरूपित, बाइनरी, पाठ या अ-स्वरूपित है।

  • DEFINE - इनपुट फ़ाइल लेआउट को परिभाषित करता है।

  • FILE - इनपुट फ़ाइल नाम और पथ निर्दिष्ट करता है।

  • INSERT - इनपुट फ़ाइल से रिकॉर्ड्स को लक्ष्य तालिका में सम्मिलित करता है।

  • END LOADING- फास्टलाड के चरण 2 की शुरुआत। लक्ष्य तालिका में रिकॉर्ड वितरित करता है।

  • LOGOFF - सभी सत्रों को समाप्त करता है और FastLoad को समाप्त करता है।

मल्टीलाड एक बार में कई तालिकाओं को लोड कर सकता है और यह विभिन्न प्रकार के कार्यों जैसे INSERT, DELETE, UPDATE और UPSERT का भी प्रदर्शन कर सकता है। यह एक बार में 5 टेबल तक लोड कर सकता है और एक स्क्रिप्ट में 20 डीएमएल ऑपरेशन तक कर सकता है। मल्टीलाड के लिए लक्ष्य तालिका की आवश्यकता नहीं है।

मल्टीआलड दो मोड का समर्थन करता है -

  • IMPORT
  • DELETE

मल्टीलोड को लक्ष्य तालिका के अलावा एक कार्य तालिका, एक लॉग टेबल और दो त्रुटि तालिका की आवश्यकता होती है।

  • Log Table - लोड के दौरान ली गई चौकियों को बनाए रखने के लिए उपयोग किया जाता है जो कि पुनरारंभ के लिए उपयोग किया जाएगा।

  • Error Tables- त्रुटि होने पर लोड के दौरान ये टेबल डाले जाते हैं। पहली त्रुटि तालिका रूपांतरण त्रुटियों को संग्रहीत करती है जबकि दूसरी त्रुटि तालिका डुप्लिकेट रिकॉर्ड संग्रहीत करती है।

  • Log Table - पुनः आरंभ करने के उद्देश्य से मल्टीलाड के प्रत्येक चरण के परिणाम बनाए रखता है।

  • Work table- मल्टीआलड स्क्रिप्ट एक काम तालिका प्रति लक्ष्य तालिका बनाता है। कार्य तालिका का उपयोग डीएमएल कार्यों और इनपुट डेटा को रखने के लिए किया जाता है।

परिसीमन

मल्टीलाड की कुछ सीमाएँ हैं।

  • विशिष्ट माध्यमिक सूचकांक लक्ष्य तालिका में समर्थित नहीं है।
  • संदर्भात्मक अखंडता समर्थित नहीं है।
  • ट्रिगर समर्थित नहीं हैं।

मल्टीलाड कैसे काम करता है

मल्टीलाड आयात के पाँच चरण हैं -

  • Phase 1 प्रारंभिक चरण - बुनियादी सेटअप गतिविधियाँ करता है।

  • Phase 2 - डीएमएल ट्रांजैक्शन फेज - डीएमएल स्टेटमेंट के सिंटैक्स को सत्यापित करता है और उन्हें टेराडाटा सिस्टम में लाता है।

  • Phase 3 - अधिग्रहण चरण - इनपुट डेटा को कार्य तालिकाओं में लाता है और तालिका को लॉक करता है।

  • Phase 4 - आवेदन चरण - सभी डीएमएल संचालन को लागू करता है।

  • Phase 5 - सफाई चरण - टेबल लॉक को रिहा करता है।

मल्टीअलाड स्क्रिप्ट में शामिल चरण हैं -

  • Step 1 - लॉग टेबल सेट करें।

  • Step 2 - Teradata पर लॉग ऑन करें।

  • Step 3 - लक्ष्य, कार्य और त्रुटि तालिका निर्दिष्ट करें।

  • Step 4 - INPUT फ़ाइल लेआउट को परिभाषित करें।

  • Step 5 - डीएमएल प्रश्नों को परिभाषित करें।

  • Step 6 - आयात फ़ाइल का नाम।

  • Step 7 - उपयोग किए जाने वाले लेआउट के बारे में बताएं।

  • Step 8 - लोड आरंभ करें।

  • Step 9 - लोड समाप्त करें और सत्र समाप्त करें।

उदाहरण

निम्नलिखित रिकॉर्ड के साथ एक टेक्स्ट फ़ाइल बनाएं और फ़ाइल को कर्मचारी के रूप में नाम दें।

101,Mike,James,1980-01-05,2010-03-01,1  
102,Robert,Williams,1983-03-05,2010-09-01,1 
103,Peter,Paul,1983-04-01,2009-02-12,2 
104,Alex,Stuart,1984-11-06,2014-01-01,2 
105,Robert,James,1984-12-01,2015-03-09,3

निम्न उदाहरण एक बहुस्तरीय स्क्रिप्ट है जो कर्मचारी तालिका से रिकॉर्ड पढ़ता है और Employee_Stg तालिका में लोड करता है।

.LOGTABLE tduser.Employee_log;  
.LOGON 192.168.1.102/dbc,dbc; 
   .BEGIN MLOAD TABLES Employee_Stg;  
      .LAYOUT Employee;  
      .FIELD in_EmployeeNo * VARCHAR(10);  
      .FIELD in_FirstName * VARCHAR(30); 
      .FIELD in_LastName * VARCHAR(30);  
      .FIELD in_BirthDate * VARCHAR(10); 
      .FIELD in_JoinedDate * VARCHAR(10);  
      .FIELD in_DepartmentNo * VARCHAR(02);

      .DML LABEL EmpLabel; 
      INSERT INTO Employee_Stg (
         EmployeeNo,
         FirstName,
         LastName,
         BirthDate,
         JoinedDate,
         DepartmentNo
      )  
      VALUES (
         :in_EmployeeNo,
         :in_FirstName,
         :in_Lastname,
         :in_BirthDate,
         :in_JoinedDate,
         :in_DepartmentNo
      );
      .IMPORT INFILE employee.txt  
      FORMAT VARTEXT ','
      LAYOUT Employee
      APPLY EmpLabel;  
   .END MLOAD;  
LOGOFF;

मल्टीलोड स्क्रिप्ट का निष्पादन

एक बार जब इनपुट फ़ाइल कर्मचारी.टेक्स्ट बनाया जाता है और मल्टीलोअड स्क्रिप्ट को EmployeeLoad.ml नाम दिया जाता है, तो आप UNIX और विंडोज में निम्न कमांड का उपयोग करके मल्टीलोड स्क्रिप्ट को चला सकते हैं।

Multiload < EmployeeLoad.ml;

FastExport यूटिलिटी का उपयोग टेराडाटा टेबल्स के डेटा को फ्लैट फ़ाइलों में निर्यात करने के लिए किया जाता है। यह रिपोर्ट प्रारूप में डेटा भी उत्पन्न कर सकता है। ज्वाइन का उपयोग करके डेटा को एक या अधिक तालिकाओं से निकाला जा सकता है। चूंकि FastExport 64K ब्लॉक में डेटा निर्यात करता है, इसलिए यह बड़ी मात्रा में डेटा निकालने के लिए उपयोगी है।

उदाहरण

निम्नलिखित कर्मचारी तालिका पर विचार करें।

कर्मचारी संख्या पहला नाम उपनाम जन्म दिन
101 माइक जेम्स 1980/01/05
104 एलेक्स स्टुअर्ट 1984/11/06
102 रॉबर्ट विलियम्स 1983/03/05
105 रॉबर्ट जेम्स 1984/12/01
103 पीटर पॉल 1983/04/01

निम्नलिखित एक FastExport स्क्रिप्ट का एक उदाहरण है। यह कर्मचारी तालिका से डेटा निर्यात करता है और एक रोजगार में लिखता है।

.LOGTABLE tduser.employee_log;  
.LOGON 192.168.1.102/dbc,dbc;  
   DATABASE tduser;  
   .BEGIN EXPORT SESSIONS 2;  
      .EXPORT OUTFILE employeedata.txt  
      MODE RECORD FORMAT TEXT;
      SELECT CAST(EmployeeNo AS CHAR(10)), 
         CAST(FirstName AS CHAR(15)), 
         CAST(LastName AS CHAR(15)), 
         CAST(BirthDate AS CHAR(10))   
      FROM
      Employee;
   .END EXPORT;
.LOGOFF;

फास्टएक्सपोर्ट स्क्रिप्ट का निष्पादन

एक बार स्क्रिप्ट लिखने और कर्मचारी के रूप में नामित होने के बाद। यदि आप स्क्रिप्ट को निष्पादित करने के लिए निम्न कमांड का उपयोग कर सकते हैं।

fexp < employee.fx

उपरोक्त कमांड को निष्पादित करने के बाद, आपको फ़ाइल में निम्नलिखित आउटपुट प्राप्त होगा।

103       Peter          Paul           1983-04-01 
101       Mike           James          1980-01-05 
102       Robert         Williams       1983-03-05 
105       Robert         James          1984-12-01 
104       Alex           Stuart         1984-11-06

FastExport शर्तें

निम्नलिखित FastExport स्क्रिप्ट में आमतौर पर उपयोग किए जाने वाले शब्दों की सूची है।

  • LOGTABLE - पुनरारंभ उद्देश्य के लिए लॉग टेबल निर्दिष्ट करता है।

  • LOGON - टेराडाटा में प्रवेश करता है और एक या अधिक सत्र आरंभ करता है।

  • DATABASE - डिफ़ॉल्ट डेटाबेस सेट करता है।

  • BEGIN EXPORT - निर्यात की शुरुआत का संकेत देता है।

  • EXPORT - लक्ष्य फ़ाइल और निर्यात प्रारूप निर्दिष्ट करता है।

  • SELECT - डेटा निर्यात करने के लिए चयन क्वेरी निर्दिष्ट करता है।

  • END EXPORT - FastExport के अंत को निर्दिष्ट करता है।

  • LOGOFF - सभी सत्रों को समाप्त करता है और FastExport को समाप्त करता है।

टेरटाटा में BTEQ उपयोगिता एक शक्तिशाली उपयोगिता है जिसका उपयोग बैच और इंटरैक्टिव मोड दोनों में किया जा सकता है। इसका उपयोग किसी भी डीडीएल स्टेटमेंट, डीएमएल स्टेटमेंट को चलाने, मैक्रोज़ बनाने और संग्रहीत प्रक्रियाओं के लिए किया जा सकता है। BTEQ का उपयोग फ्लैट फाइल से टेराडाटा टेबलों में डेटा आयात करने के लिए किया जा सकता है और इसका उपयोग टेबलों से फाइल या रिपोर्ट में डेटा निकालने के लिए भी किया जा सकता है।

BTEQ नियम

निम्नलिखित BTEQ लिपियों में आमतौर पर उपयोग किए जाने वाले शब्दों की सूची है।

  • LOGON - टेराडाटा प्रणाली में लॉग इन करने के लिए उपयोग किया जाता है।

  • ACTIVITYCOUNT - पिछली क्वेरी से प्रभावित पंक्तियों की संख्या लौटाता है।

  • ERRORCODE - पिछली क्वेरी का स्टेटस कोड लौटाता है।

  • DATABASE - डिफ़ॉल्ट डेटाबेस सेट करता है।

  • LABEL - SQL कमांड के एक सेट पर एक लेबल असाइन करता है।

  • RUN FILE - एक फ़ाइल में निहित क्वेरी निष्पादित करता है।

  • GOTO - एक लेबल पर स्थानांतरण नियंत्रण।

  • LOGOFF - डेटाबेस से लॉग इन करता है और सभी सत्रों को समाप्त करता है।

  • IMPORT - इनपुट फ़ाइल पथ निर्दिष्ट करता है।

  • EXPORT - आउटपुट फ़ाइल पथ निर्दिष्ट करता है और निर्यात शुरू करता है।

उदाहरण

निम्नलिखित एक नमूना BTEQ स्क्रिप्ट है।

.LOGON 192.168.1.102/dbc,dbc; 
   DATABASE tduser;

   CREATE TABLE employee_bkup ( 
      EmployeeNo INTEGER, 
      FirstName CHAR(30), 
      LastName CHAR(30), 
      DepartmentNo SMALLINT, 
      NetPay INTEGER 
   )
   Unique Primary Index(EmployeeNo);

   .IF ERRORCODE <> 0 THEN .EXIT ERRORCODE;
  
   SELECT * FROM  
   Employee 
   Sample 1; 
   .IF ACTIVITYCOUNT <> 0 THEN .GOTO InsertEmployee;  

   DROP TABLE employee_bkup;
  
   .IF ERRORCODE <> 0 THEN .EXIT ERRORCODE; 
 
   .LABEL InsertEmployee 
   INSERT INTO employee_bkup 
   SELECT a.EmployeeNo, 
      a.FirstName, 
      a.LastName, 
      a.DepartmentNo, 
      b.NetPay 
   FROM  
   Employee a INNER JOIN Salary b 
   ON (a.EmployeeNo = b.EmployeeNo);  

   .IF ERRORCODE <> 0 THEN .EXIT ERRORCODE; 
.LOGOFF;

उपरोक्त स्क्रिप्ट निम्नलिखित कार्य करती है।

  • टेराडाटा सिस्टम में प्रवेश करता है।

  • डिफ़ॉल्ट डेटाबेस सेट करता है।

  • एक तालिका बनाता है जिसे कर्मचारी_बकूप कहा जाता है।

  • यह जाँचने के लिए कि कर्मचारी के पास टेबल से कोई रिकॉर्ड है या नहीं।

  • कर्मचारी टेबल को खाली करता है, तो कर्मचारी_bkup तालिका को छोड़ देता है।

  • एक लेबल InsertEmployee पर नियंत्रण स्थानांतरित करता है जो कर्मचारी_बेकअप तालिका में रिकॉर्ड सम्मिलित करता है

  • यह सुनिश्चित करने के लिए ERRORCODE की जाँच करता है कि प्रत्येक SQL कथन का अनुसरण करते हुए कथन सफल है।

  • पिछले SQL क्वेरी द्वारा चयनित / प्रभावित रिकॉर्डों का ACTIVITYCOUNT रिटर्न देता है।