टेराडाटा - मल्टीऑलड
मल्टीलाड एक बार में कई तालिकाओं को लोड कर सकता है और यह विभिन्न प्रकार के कार्यों जैसे 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;