IMS DB - डेटा हेरफेर
IMS DL / I कॉल में उपयोग किए जाने वाले विभिन्न डेटा हेरफेर तरीके निम्नानुसार हैं -
- ISRT कॉल
- होल्ड कॉल प्राप्त करें
- REPL कॉल
- DLET कॉल
आइए डेटा हेरफेर फ़ंक्शन कॉल को समझने के लिए निम्नलिखित IMS डेटाबेस संरचना पर विचार करें -
ISRT कॉल
नोट करने के लिए अंक -
ISRT कॉल को इन्सर्ट कॉल के रूप में जाना जाता है जिसका उपयोग किसी डेटाबेस में सेगमेंट की घटनाओं को जोड़ने के लिए किया जाता है।
ISRT कॉल एक नया डेटाबेस लोड करने के लिए उपयोग किया जाता है।
हम एक ISRT कॉल जारी करते हैं जब एक सेगमेंट विवरण फ़ील्ड को डेटा के साथ लोड किया जाता है।
एक अयोग्य या योग्य एसएसए को कॉल में निर्दिष्ट किया जाना चाहिए ताकि डीएल / मुझे पता है कि एक खंड घटना कहां रखी जाए।
हम कॉल में अयोग्य और योग्य SSA दोनों के संयोजन का उपयोग कर सकते हैं। उपरोक्त सभी स्तरों के लिए एक योग्य एसएसए निर्दिष्ट किया जा सकता है। आइए हम निम्नलिखित उदाहरण पर विचार करें -
CALL 'CBLTDLI' USING DLI-ISRT
PCB-NAME
IO-AREA
LIBRARY-SSA
BOOKS-SSA
UNQUALIFIED-ENGINEERING-SSA
उपरोक्त उदाहरण से पता चलता है कि हम योग्य और अयोग्य SSAs का संयोजन प्रदान करके ISRT कॉल जारी कर रहे हैं।
जब एक नया खंड जिसे हम सम्मिलित कर रहे हैं, में एक विशिष्ट कुंजी फ़ील्ड है, तो उसे उचित स्थिति में जोड़ा जाता है। यदि कुंजी फ़ील्ड अद्वितीय नहीं है, तो इसे डेटाबेस व्यवस्थापक द्वारा परिभाषित नियमों द्वारा जोड़ा जाता है।
जब हम एक प्रमुख क्षेत्र को निर्दिष्ट किए बिना आईएसआरटी कॉल जारी करते हैं, तो इंसर्ट नियम बताता है कि मौजूदा जुड़वां खंडों के सापेक्ष खंडों को कहां रखा जाए। नीचे दिए गए सम्मिलित नियम हैं -
First - यदि नियम पहले है, तो किसी भी मौजूदा जुड़वा बच्चों से पहले नया खंड जोड़ा जाता है।
Last - यदि नियम अंतिम है, तो सभी मौजूदा जुड़वा बच्चों के बाद नया खंड जोड़ा जाता है।
Here - यदि नियम यहां है, तो इसे मौजूदा स्थिति में मौजूदा जुड़वा बच्चों के सापेक्ष जोड़ा जाता है, जो पहले, अंतिम या कहीं भी हो सकता है।
स्थिति कोड
निम्न तालिका ISRT कॉल के बाद प्रासंगिक स्थिति कोड दिखाती है -
S.No | स्थिति कोड और विवरण |
---|---|
1 | Spaces सफल कॉल |
2 | GE एकाधिक SSAs का उपयोग किया जाता है और DL / I निर्दिष्ट पथ के साथ कॉल को संतुष्ट नहीं कर सकता है। |
3 | II डेटाबेस में पहले से मौजूद एक खंड घटना को जोड़ने का प्रयास करें। |
4 | LB / LC LD / LE हमें ये स्थिति कोड लोड प्रोसेसिंग के दौरान मिलते हैं। ज्यादातर मामलों में, वे संकेत देते हैं कि आप एक सटीक श्रेणीबद्ध अनुक्रम में सेगमेंट नहीं डाल रहे हैं। |
होल्ड कॉल प्राप्त करें
नोट करने के लिए अंक -
तीन प्रकार के गेट होल्ड कॉल हैं जिन्हें हम DL / I कॉल में निर्दिष्ट करते हैं:
अद्वितीय पकड़ो (GHU)
अगले पकड़ (GHN)
अभिभावक (GHNP) के भीतर अगला भाग प्राप्त करें
होल्ड फ़ंक्शन निर्दिष्ट करता है कि हम पुनर्प्राप्ति के बाद खंड को अपडेट करने जा रहे हैं। इसलिए REPL या DLET कॉल से पहले, डेटाबेस को अपडेट करने के इरादे से DL / I को बताकर एक सफल होल्ड कॉल जारी किया जाना चाहिए।
REPL कॉल
नोट करने के लिए अंक -
एक सफल होल्ड कॉल के बाद, हम एक सेगमेंट घटना को अपडेट करने के लिए एक REPL कॉल जारी करते हैं।
हम REPL कॉल का उपयोग करके किसी खंड की लंबाई नहीं बदल सकते।
हम REPL कॉल का उपयोग करके एक महत्वपूर्ण फ़ील्ड का मान नहीं बदल सकते।
हम REPL कॉल के साथ एक योग्य SSA का उपयोग नहीं कर सकते। यदि हम एक योग्य एसएसए निर्दिष्ट करते हैं, तो कॉल विफल हो जाती है।
CALL 'CBLTDLI' USING DLI-GHU
PCB-NAME
IO-AREA
LIBRARY-SSA
BOOKS-SSA
ENGINEERING-SSA
IT-SSA.
*Move the values which you want to update in IT segment occurrence*
CALL ‘CBLTDLI’ USING DLI-REPL
PCB-NAME
IO-AREA.
उपरोक्त उदाहरण एक REPL कॉल का उपयोग करके आईटी खंड घटना को अद्यतन करता है। सबसे पहले, हम उस खंड घटना को प्राप्त करने के लिए GHU कॉल जारी करते हैं जिसे हम अपडेट करना चाहते हैं। फिर, हम उस सेगमेंट के मूल्यों को अपडेट करने के लिए एक REPL कॉल जारी करते हैं।
DLET कॉल
नोट करने के लिए अंक -
डीएलईटी कॉल उसी तरह से काम करता है जिस तरह से आरईपीएल कॉल करता है।
एक सफल होल्ड कॉल के बाद, हम एक खंड घटना को हटाने के लिए DLET कॉल जारी करते हैं।
हम DLET कॉल के साथ एक योग्य SSA का उपयोग नहीं कर सकते हैं। यदि हम एक योग्य एसएसए निर्दिष्ट करते हैं, तो कॉल विफल हो जाती है।
CALL 'CBLTDLI' USING DLI-GHU
PCB-NAME
IO-AREA
LIBRARY-SSA
BOOKS-SSA
ENGINEERING-SSA
IT-SSA.
CALL ‘CBLTDLI’ USING DLI-DLET
PCB-NAME
IO-AREA.
उपरोक्त उदाहरण डीएलईटी कॉल का उपयोग करके आईटी सेगमेंट की घटना को हटाता है। सबसे पहले, हम उस खंड घटना को प्राप्त करने के लिए एक GHU कॉल जारी करते हैं जिसे हम हटाना चाहते हैं। फिर, हम उस सेगमेंट के मूल्यों को अपडेट करने के लिए DLET कॉल जारी करते हैं।
स्थिति कोड
निम्न तालिका REPL या DLET कॉल के बाद प्रासंगिक स्थिति कोड दिखाती है -
S.No | स्थिति कोड और विवरण |
---|---|
1 | Spaces सफल कॉल |
2 | AJ योग्य SSA REPL या DLET कॉल पर उपयोग किया जाता है। |
3 | DJ कार्यक्रम एक तत्काल कॉल के बिना एक प्रतिस्थापित कॉल जारी करता है, होल्ड कॉल प्राप्त करें। |
4 | DA कार्यक्रम REPL या DLET कॉल जारी करने से पहले खंड के प्रमुख क्षेत्र में बदलाव करता है |