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 कॉल जारी करने से पहले खंड के प्रमुख क्षेत्र में बदलाव करता है