टेराडाटा - फास्टलाड
फास्टलैड उपयोगिता का उपयोग डेटा को खाली तालिकाओं में लोड करने के लिए किया जाता है। चूंकि यह क्षणिक पत्रिकाओं का उपयोग नहीं करता है, इसलिए डेटा को जल्दी से लोड किया जा सकता है। यह डुप्लिकेट पंक्तियों को लोड नहीं करता है, भले ही लक्ष्य तालिका एक 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 - सभी सत्रों को समाप्त करता है और फास्टलाड को समाप्त करता है।