आईएमएस डीबी - त्वरित गाइड

संक्षिप्त विवरण

डेटाबेस सहसंबद्ध डेटा आइटम का एक संग्रह है। इन डेटा आइटम्स को तेज और आसान पहुंच प्रदान करने के लिए व्यवस्थित और संग्रहीत किया जाता है। IMS डेटाबेस एक पदानुक्रमित डेटाबेस है जहाँ डेटा को विभिन्न स्तरों पर संग्रहीत किया जाता है और प्रत्येक इकाई उच्च स्तर की संस्थाओं पर निर्भर होती है। IMS का उपयोग करने वाले एक एप्लिकेशन सिस्टम पर भौतिक तत्व निम्नलिखित आकृति में दिखाए गए हैं।

डेटाबेस प्रबंधन

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

लेन-देन प्रबंधक

लेन-देन प्रबंधक का कार्य डेटाबेस और एप्लिकेशन प्रोग्राम के बीच एक संचार मंच प्रदान करना है। IMS एक लेनदेन प्रबंधक के रूप में कार्य करता है। एक लेनदेन प्रबंधक डेटाबेस से डेटा को संग्रहीत करने और पुनर्प्राप्त करने के लिए अंतिम-उपयोगकर्ता के साथ व्यवहार करता है। IMS डेटा को स्टोर करने के लिए IMS DB या DB2 को इसके बैक-एंड डेटाबेस के रूप में उपयोग कर सकता है।

DL / I - डेटा भाषा इंटरफ़ेस

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

आईएमएस के लक्षण

नोट करने के लिए अंक -

  • IMS जावा और XML जैसी विभिन्न भाषाओं के अनुप्रयोगों का समर्थन करता है।
  • IMS एप्लिकेशन और डेटा को किसी भी प्लेटफॉर्म पर एक्सेस किया जा सकता है।
  • DB2 की तुलना में IMS DB प्रसंस्करण बहुत तेज है।

आईएमएस की सीमाएं

नोट करने के लिए अंक -

  • IMS DB का कार्यान्वयन बहुत जटिल है।
  • IMS पूर्वनिर्धारित पेड़ संरचना लचीलापन कम कर देता है।
  • IMS DB का प्रबंधन करना मुश्किल है।

वर्गीकृत संरचना

IMS डेटाबेस भौतिक फ़ाइलों को समायोजित करने वाला डेटा का एक संग्रह है। एक पदानुक्रमित डेटाबेस में, शीर्ष स्तर में इकाई के बारे में सामान्य जानकारी होती है। जैसा कि हम पदानुक्रम में शीर्ष स्तर से निचले स्तर तक आगे बढ़ते हैं, हमें इकाई के बारे में अधिक से अधिक जानकारी मिलती है।

पदानुक्रम में प्रत्येक स्तर में खंड होते हैं। मानक फाइलों में, पदानुक्रमों को लागू करना मुश्किल है, लेकिन DL / I पदानुक्रमों का समर्थन करता है। निम्नलिखित आंकड़ा IMS DB की संरचना को दर्शाता है।

खंड

नोट करने के लिए अंक -

  • एक सेगमेंट को एक साथ समान डेटा के समूह द्वारा बनाया जाता है।

  • यह जानकारी की सबसे छोटी इकाई है जो DL / I किसी भी इनपुट-आउटपुट ऑपरेशन के दौरान एक एप्लिकेशन प्रोग्राम से और उससे स्थानांतरित करता है।

  • एक खंड में एक या अधिक डेटा फ़ील्ड एक साथ समूहीकृत हो सकते हैं।

निम्नलिखित उदाहरण में, खंड छात्र के पास चार डेटा फ़ील्ड हैं।

छात्र
रोल नंबर नाम कोर्स मोबाइल नंबर

मैदान

ध्यान देने की बात

  • एक क्षेत्र एक खंड में डेटा का एक टुकड़ा है। उदाहरण के लिए, छात्र संख्या में रोल नंबर, नाम, पाठ्यक्रम और मोबाइल नंबर एकल क्षेत्र हैं।

  • एक खंड में एक इकाई की जानकारी एकत्र करने के लिए संबंधित क्षेत्र होते हैं।

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

  • किसी विशेष खंड के बारे में जानकारी खोजने के लिए फ़ील्ड का उपयोग क्वालिफायर के रूप में किया जा सकता है।

खंड प्रकार

नोट करने के लिए अंक -

  • सेगमेंट प्रकार एक सेगमेंट में डेटा की एक श्रेणी है।

  • एक DL / I डेटाबेस में 255 विभिन्न खंड प्रकार और पदानुक्रम के 15 स्तर हो सकते हैं।

  • निम्नलिखित आंकड़े में, तीन खंड हैं, पुस्तकालय, पुस्तकें सूचना और छात्र सूचना।

खंड घटना

नोट करने के लिए अंक -

  • एक खंड घटना उपयोगकर्ता डेटा वाले एक विशेष प्रकार का एक व्यक्तिगत खंड है। उपरोक्त उदाहरण में, Books Information एक सेगमेंट प्रकार है और इसके किसी भी प्रकार की घटनाएँ हो सकती हैं, क्योंकि यह किसी भी संख्या में पुस्तकों के बारे में जानकारी संग्रहीत कर सकती है।

  • IMS डेटाबेस के भीतर, प्रत्येक सेगमेंट के प्रकार की केवल एक घटना होती है, लेकिन प्रत्येक सेगमेंट के प्रकार की असीमित संख्या हो सकती है।

पदानुक्रमित डेटाबेस दो या अधिक खंडों के बीच संबंधों पर काम करते हैं। निम्न उदाहरण दिखाता है कि IMS डेटाबेस संरचना में खंड एक दूसरे से कैसे संबंधित हैं।

रूट सेगमेंट

नोट करने के लिए अंक -

  • पदानुक्रम के शीर्ष पर स्थित खंड को मूल खंड कहा जाता है।

  • रूट सेगमेंट एकमात्र ऐसा सेगमेंट है, जिसके माध्यम से सभी आश्रित सेगमेंट एक्सेस किए जाते हैं।

  • रूट सेगमेंट डेटाबेस में एकमात्र सेगमेंट है जो कभी भी चाइल्ड सेगमेंट नहीं है।

  • IMS डेटाबेस संरचना में केवल एक रूट सेगमेंट हो सकता है।

  • उदाहरण के लिए, 'A' उपरोक्त उदाहरण में रूट सेगमेंट है।

जनक खंड

नोट करने के लिए अंक -

  • एक मूल खंड में एक या एक से अधिक आश्रित खंड होते हैं जो सीधे उसके नीचे होते हैं।

  • उदाहरण के लिए, 'A''B', तथा 'E' उपरोक्त उदाहरण में मूल खंड हैं।

आश्रित खंड

नोट करने के लिए अंक -

  • रूट सेगमेंट के अलावा अन्य सभी सेगमेंट को डिपेंडेंट सेगमेंट के रूप में जाना जाता है।

  • आश्रित खंड पूर्ण अर्थ प्रस्तुत करने के लिए एक या अधिक खंडों पर निर्भर करते हैं।

  • उदाहरण के लिए, 'B', 'C1', 'C2', 'D', 'E', 'F1' तथा 'F2' हमारे उदाहरण में निर्भर खंड हैं।

बाल खंड

नोट करने के लिए अंक -

  • पदानुक्रम में सीधे ऊपर सेगमेंट वाले किसी भी सेगमेंट को चाइल्ड सेगमेंट के रूप में जाना जाता है।

  • संरचना में प्रत्येक आश्रित खंड एक बाल खंड है।

  • उदाहरण के लिए, 'B', 'C1', 'C2', 'D', 'E', 'F1' तथा 'F2' बाल खंड हैं।

जुड़वां खंड

नोट करने के लिए अंक -

  • किसी एकल पैरेंट सेगमेंट के अंतर्गत किसी विशेष सेगमेंट प्रकार के दो या अधिक सेगमेंट की घटनाओं को ट्विन सेगमेंट कहा जाता है।

  • उदाहरण के लिए, 'C1' तथा 'C2' ट्विन सेगमेंट हैं, इसलिए करते हैं 'F1' तथा 'F2' कर रहे हैं।

सिबलिंग सेगमेंट

नोट करने के लिए अंक -

  • सिबलिंग सेगमेंट अलग-अलग प्रकार के सेगमेंट हैं और एक ही माता-पिता हैं।

  • उदाहरण के लिए, 'B' तथा 'E' सहोदर खंड हैं। इसी तरह,'C1', 'C2', तथा 'D' सहोदर खंड हैं।

डेटाबेस रिकॉर्ड

नोट करने के लिए अंक -

  • रूट सेगमेंट की प्रत्येक घटना, साथ ही सभी अधीनस्थ खंड घटनाएँ एक डेटाबेस रिकॉर्ड बनाती हैं।

  • प्रत्येक डेटाबेस रिकॉर्ड में केवल एक रूट सेगमेंट होता है, लेकिन इसमें सेगमेंट की कोई भी संख्या हो सकती है।

  • मानक फ़ाइल प्रसंस्करण में, एक रिकॉर्ड डेटा की एक इकाई है जो एक एप्लिकेशन प्रोग्राम कुछ कार्यों के लिए उपयोग करता है। DL / I में, डेटा की उस इकाई को एक सेगमेंट के रूप में जाना जाता है। एक एकल डेटाबेस रिकॉर्ड में कई खंड होते हैं।

डेटाबेस पथ

नोट करने के लिए अंक -

  • एक पथ खंडों की श्रृंखला है जो डेटाबेस रिकॉर्ड के रूट खंड से किसी भी विशिष्ट खंड की घटना से शुरू होता है।

  • पदानुक्रम संरचना में एक पथ को न्यूनतम स्तर तक पूरा करने की आवश्यकता नहीं है। यह इस बात पर निर्भर करता है कि हमें किसी इकाई के बारे में कितनी जानकारी चाहिए।

  • एक पथ निरंतर होना चाहिए और हम संरचना में मध्यवर्ती स्तरों को छोड़ नहीं सकते हैं।

  • निम्नलिखित आंकड़े में, बच्चे को गहरे भूरे रंग में रिकॉर्ड किया गया है जो एक रास्ता दिखाता है जो शुरू होता है 'A' और गुजरता है 'C2'

IMS DB विभिन्न स्तरों पर डेटा संग्रहीत करता है। एक आवेदन कार्यक्रम से डीएल / आई कॉल जारी करके डेटा को पुनर्प्राप्त और डाला जाता है। हम आगामी अध्यायों में डीएल / आई कॉल के बारे में विस्तार से चर्चा करेंगे। डेटा को निम्नलिखित दो तरीकों से संसाधित किया जा सकता है -

  • अनुक्रमिक प्रसंस्करण
  • यादृच्छिक प्रसंस्करण

अनुक्रमिक प्रसंस्करण

जब खंडों को डेटाबेस से क्रमिक रूप से पुनर्प्राप्त किया जाता है, तो DL / I एक पूर्वनिर्धारित पैटर्न का अनुसरण करता है। आइए हम IMS DB के अनुक्रमिक प्रसंस्करण को समझते हैं।

अनुक्रमित प्रसंस्करण के बारे में ध्यान देने योग्य बिंदु नीचे सूचीबद्ध हैं -

  • DL / I में डेटा एक्सेस करने के लिए पूर्वनिर्धारित पैटर्न पहले पदानुक्रम नीचे है, फिर दाएं से बाएं।

  • रूट सेगमेंट को पहले प्राप्त किया जाता है, फिर DL / I पहले बाएं बच्चे के पास जाता है और यह सबसे निचले स्तर तक नीचे चला जाता है। निम्नतम स्तर पर, यह जुड़वाँ खंडों की सभी घटनाओं को पुनः प्राप्त करता है। फिर यह सही सेगमेंट में जाता है।

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

  • डेटा एक्सेस करते समय, प्रोग्राम का उपयोग करता है position डेटाबेस में जो खंडों को पुनः प्राप्त करने और सम्मिलित करने में मदद करता है।

यादृच्छिक प्रसंस्करण

आईएमएस डीबी में रैंडम प्रोसेसिंग को डेटा की डायरेक्ट प्रोसेसिंग के रूप में भी जाना जाता है। आइए हम IMS DB में यादृच्छिक प्रसंस्करण को समझने के लिए एक उदाहरण लेते हैं -

नीचे सूचीबद्ध हैं यादृच्छिक प्रसंस्करण के बारे में ध्यान देने योग्य बिंदु -

  • खंड की घटना जिसे पुनः प्राप्त करने की आवश्यकता होती है, उसे उन सभी खंडों के प्रमुख क्षेत्रों की आवश्यकता होती है, जो उस पर निर्भर करता है। इन प्रमुख क्षेत्रों को आवेदन कार्यक्रम द्वारा आपूर्ति की जाती है।

  • एक संक्षिप्त कुंजी पूरी तरह से रूट सेगमेंट के उस सेगमेंट की पहचान करती है जिसे आप पुनः प्राप्त करना चाहते हैं।

  • मान लीजिए कि आप कॉमर्स सेगमेंट की एक घटना को पुनः प्राप्त करना चाहते हैं, तो आपको उन सेगमेंट के प्रमुख फ़ील्ड मानों की आपूर्ति करने की आवश्यकता होती है, जो इस पर निर्भर करता है, जैसे लाइब्रेरी, बुक्स और कॉमर्स।

  • यादृच्छिक प्रसंस्करण अनुक्रमिक प्रसंस्करण से तेज है। वास्तविक दुनिया के परिदृश्य में, एप्लिकेशन सर्वोत्तम परिणाम प्राप्त करने के लिए अनुक्रमिक और यादृच्छिक प्रसंस्करण विधियों दोनों को एक साथ जोड़ते हैं।

मुख्य क्षेत्र

नोट करने के लिए अंक -

  • एक प्रमुख क्षेत्र को अनुक्रम क्षेत्र के रूप में भी जाना जाता है।

  • एक मुख्य फ़ील्ड एक सेगमेंट के भीतर मौजूद है और इसका उपयोग सेगमेंट की घटना को पुनः प्राप्त करने के लिए किया जाता है।

  • एक प्रमुख क्षेत्र आरोही क्रम में खंड की घटना का प्रबंधन करता है।

  • प्रत्येक सेगमेंट में, केवल एक फ़ील्ड को एक महत्वपूर्ण फ़ील्ड या अनुक्रम फ़ील्ड के रूप में उपयोग किया जा सकता है।

खोज क्षेत्र

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

IMS नियंत्रण ब्लॉक IMS डेटाबेस की संरचना और उनके लिए एक कार्यक्रम की पहुंच को परिभाषित करता है। निम्नलिखित आरेख IMS नियंत्रण ब्लॉकों की संरचना को दर्शाता है।

DL / I नियंत्रण ब्लॉक के तीन प्रकारों का उपयोग करता है -

  • डेटाबेस डिस्क्रिप्टर (DBD)
  • कार्यक्रम विशिष्टता ब्लॉक (PSB)
  • एक्सेस कंट्रोल ब्लॉक (ACB)

डेटाबेस डिस्क्रिप्टर (DBD)

नोट करने के लिए अंक -

  • सभी खंडों को परिभाषित करने के बाद DBD डेटाबेस की पूरी भौतिक संरचना का वर्णन करता है।

  • DL / I डेटाबेस को स्थापित करते समय, एक DBD ​​बनाना होगा क्योंकि IMS डेटाबेस तक पहुँचने के लिए यह आवश्यक है।

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

  • डेटाबेस एडमिनिस्ट्रेटर कोडिंग द्वारा DBD बनाता है DBDGEN नियंत्रण कथनों।

DBDGEN

DBDGEN एक डेटाबेस डिस्क्रिप्टर जेनरेटर है। नियंत्रण ब्लॉक बनाना डेटाबेस प्रशासक की जिम्मेदारी है। सभी लोड मॉड्यूल IMS लाइब्रेरी में संग्रहीत किए जाते हैं। असेंबली लैंग्वेज मैक्रो स्टेटमेंट का उपयोग कंट्रोल ब्लॉक बनाने के लिए किया जाता है। नीचे एक नमूना कोड दिया गया है जो दिखाता है कि DBDGEN नियंत्रण कथनों का उपयोग करके DBD कैसे बनाया जाता है -

PRINT	NOGEN
DBD	NAME=LIBRARY,ACCESS=HIDAM
DATASET	DD1=LIB,DEVICE=3380
SEGM	NAME=LIBSEG,PARENT=0,BYTES=10
FIELD	NAME=(LIBRARY,SEQ,U),BYTES=10,START=1,TYPE=C
SEGM	NAME=BOOKSEG,PARENT=LIBSEG,BYTES=5
FIELD	NAME=(BOOKS,SEQ,U),BYTES=10,START=1,TYPE=C
SEGM	NAME=MAGSEG,PARENT=LIBSEG,BYTES=9
FIELD	NAME=(MAGZINES,SEQ),BYTES=8,START=1,TYPE=C
DBDGEN
FINISH
END

आइये उपरोक्त DBDGEN में प्रयुक्त शब्दों को समझते हैं -

  • जब आप उपरोक्त नियंत्रण कथनों को निष्पादित करते हैं JCL, यह एक भौतिक संरचना बनाता है जहां LIBRARY जड़ खंड है, और किताबें और पत्रिकाएं इसके बाल खंड हैं।

  • पहला DBD मैक्रो स्टेटमेंट डेटाबेस की पहचान करता है। यहां, हमें इस डेटाबेस को एक्सेस करने के लिए NAME और ACCESS का उल्लेख करने की आवश्यकता है जो DL / I द्वारा उपयोग किया जाता है।

  • दूसरा DATASET मैक्रो स्टेटमेंट उस फ़ाइल की पहचान करता है जिसमें डेटाबेस होता है।

  • खंड प्रकार को SEGM मैक्रो स्टेटमेंट का उपयोग करके परिभाषित किया गया है। हमें उस सेगमेंट के हिस्से को निर्दिष्ट करने की आवश्यकता है। यदि यह एक रूट सेगमेंट है, तो PARENT = 0 का उल्लेख करें।

निम्न तालिका FIELD मैक्रो स्टेटमेंट में उपयोग किए गए मापदंडों को दिखाती है -

S.No पैरामीटर और विवरण
1

Name

क्षेत्र का नाम, आम तौर पर 1 से 8 वर्ण लंबा

2

Bytes

मैदान की लंबाई

3

Start

खंड के भीतर क्षेत्र की स्थिति

4

Type

क्षेत्र का डेटा प्रकार

5

Type C

चरित्र डेटा प्रकार

6

Type P

पैक्ड दशमलव डेटा प्रकार

7

Type Z

Zoned दशमलव डेटा प्रकार

8

Type X

हेक्साडेसिमल डेटा प्रकार

9

Type H

आधा शब्द द्विआधारी डेटा प्रकार

10

Type F

पूर्ण शब्द बाइनरी डेटा प्रकार

कार्यक्रम विशिष्टता ब्लॉक (PSB)

PSB के मूल तत्व नीचे दिए गए हैं -

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

  • कोई भी प्रोग्राम एक निष्पादन में एक से अधिक PSB का उपयोग नहीं कर सकता है।

  • एप्लिकेशन प्रोग्राम का अपना PSB है और यह उन एप्लिकेशन प्रोग्राम के लिए आम है जिनके पास PSB को साझा करने के लिए समान डेटाबेस प्रोसेसिंग आवश्यकताएं हैं।

  • PSB में प्रोग्राम कम्युनिकेशन ब्लॉक्स (PCB) नामक एक या अधिक नियंत्रण ब्लॉक होते हैं। PSB में प्रत्येक DL / I डेटाबेस के लिए एक पीसीबी होता है, जो एप्लिकेशन प्रोग्राम एक्सेस करेगा। हम आगामी मॉड्यूल में PCBs के बारे में अधिक चर्चा करेंगे।

  • कार्यक्रम के लिए PSB बनाने के लिए PSBGEN का प्रदर्शन किया जाना चाहिए।

PSBGEN

PSBGEN को प्रोग्राम स्पेसिफिकेशन ब्लॉक जेनरेटर के रूप में जाना जाता है। निम्न उदाहरण PSBGEN का उपयोग करके PSB बनाता है -

PRINT   NOGEN
PCB     TYPE=DB,DBDNAME=LIBRARY,KEYLEN=10,PROCOPT=LS
SENSEG  NAME=LIBSEG
SENSEG  NAME=BOOKSEG,PARENT=LIBSEG
SENSEG  NAME=MAGSEG,PARENT=LIBSEG
PSBGEN  PSBNAME=LIBPSB,LANG=COBOL
END

आइये उपरोक्त DBDGEN में प्रयुक्त शब्दों को समझते हैं -

  • पहला मैक्रो स्टेटमेंट प्रोग्राम कम्युनिकेशन ब्लॉक (पीसीबी) है जो डेटाबेस प्रकार, नाम, की-लेंथ और प्रोसेसिंग विकल्प का वर्णन करता है।

  • पीसीबी मैक्रो पर DBDNAME पैरामीटर DBD का नाम निर्दिष्ट करता है। KEYLEN सबसे लंबी समतल कुंजी की लंबाई निर्दिष्ट करता है। प्रोग्राम डेटाबेस में प्रोसेस कर सकता है। PROCOPT पैरामीटर प्रोग्राम के प्रसंस्करण विकल्पों को निर्दिष्ट करता है। उदाहरण के लिए, LS का अर्थ केवल LOAD ऑपरेशंस है।

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

  • अंतिम मैक्रो स्टेटमेंट PCBGEN है। PSBGEN अंतिम कथन है जो यह बताता है कि प्रक्रिया के लिए कोई और कथन नहीं हैं। PSBNAME आउटपुट PSB मॉड्यूल को दिए गए नाम को परिभाषित करता है। LANG पैरामीटर उस भाषा को निर्दिष्ट करता है जिसमें एप्लिकेशन प्रोग्राम लिखा जाता है, जैसे, COBOL।

एक्सेस कंट्रोल ब्लॉक (ACB)

नीचे सूचीबद्ध बिंदुओं तक पहुंच नियंत्रण ब्लॉकों के बारे में ध्यान देने योग्य हैं -

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

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

  • ऑनलाइन कार्यक्रमों के लिए, हमें एसीबी को पूर्व-निर्मित करने की आवश्यकता है। इसलिए ACBGEN उपयोगिता को एप्लिकेशन प्रोग्राम निष्पादित करने से पहले निष्पादित किया जाता है।

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

एक एप्लिकेशन प्रोग्राम जिसमें DL / I कॉल शामिल हैं, सीधे निष्पादित नहीं कर सकते हैं। इसके बजाय, IMS DL / I बैच मॉड्यूल को ट्रिगर करने के लिए एक JCL आवश्यक है। IMS में बैच इनिशियलाइज़ेशन मॉड्यूल DFSRRC00 है। एप्लिकेशन प्रोग्राम और DL / I मॉड्यूल एक साथ निष्पादित होते हैं। निम्न आरेख एक एप्लिकेशन प्रोग्राम की संरचना को दर्शाता है जिसमें एक डेटाबेस तक पहुंचने के लिए डीएल / आई कॉल शामिल है।

आवेदन कार्यक्रम में निम्नलिखित कार्यक्रम तत्वों के माध्यम से आईएमएस डीएल / आई मॉड्यूल के साथ इंटरफेस है -

  • एक एनटीआरवाई कथन निर्दिष्ट करता है कि पीसीबी प्रोग्राम द्वारा उपयोग किए जाते हैं।

  • एक पीसीबी-मुखौटा पूर्व-निर्मित पीसीबी में संरक्षित जानकारी के साथ सह-संबंधित है जो आईएमएस से वापसी की जानकारी प्राप्त करता है।

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

  • डीएल / I को कॉल्स प्रोसेसिंग फ़ंक्शंस जैसे कि फ़ेच, इंसर्ट, डिलीट, रिप्लेस इत्यादि को निर्दिष्ट करते हैं।

  • स्थिति कोड की जाँच करें कि क्या ऑपरेशन सफल था या नहीं यह बताने के लिए निर्दिष्ट प्रसंस्करण विकल्प के SQL रिटर्न कोड की जाँच करने के लिए उपयोग किया जाता है।

  • एक टर्मिनेट स्टेटमेंट का उपयोग एप्लिकेशन प्रोग्राम की प्रोसेसिंग को समाप्त करने के लिए किया जाता है जिसमें DL / I शामिल होता है।

खंड लेआउट

अब तक, हमें पता चला कि IMS में सेगमेंट होते हैं जो डेटा तक पहुंचने के लिए उच्च-स्तरीय प्रोग्रामिंग भाषाओं में उपयोग किए जाते हैं। लाइब्रेरी के निम्नलिखित IMS डेटाबेस संरचना पर विचार करें, जिसे हमने पहले देखा है और यहाँ हम COBOL में इसके खंडों का लेआउट देखते हैं -

01 LIBRARY-SEGMENT.
   05 BOOK-ID        PIC X(5).
   05 ISSUE-DATE     PIC X(10).
   05 RETURN-DATE    PIC X(10).
   05 STUDENT-ID     PIC A(25).
	
01 BOOK-SEGMENT.
   05 BOOK-ID        PIC X(5).
   05 BOOK-NAME      PIC A(30).
   05 AUTHOR         PIC A(25).
	
01 STUDENT-SEGMENT.
   05 STUDENT-ID     PIC X(5).
   05 STUDENT-NAME   PIC A(25).
   05 DIVISION       PIC X(10).

आवेदन कार्यक्रम अवलोकन

IMS एप्लिकेशन प्रोग्राम की संरचना एक गैर-IMS एप्लिकेशन प्रोग्राम से भिन्न होती है। IMS प्रोग्राम को सीधे निष्पादित नहीं किया जा सकता है; बल्कि इसे हमेशा सबरूटीन कहा जाता है। IMS डेटाबेस के एक दृश्य प्रदान करने के लिए एक IMS एप्लिकेशन प्रोग्राम में प्रोग्राम स्पेसिफिकेशन ब्लॉक होते हैं।

उस प्रोग्राम से जुड़े एप्लिकेशन प्रोग्राम और PSB लोड होते हैं जब हम एक एप्लिकेशन प्रोग्राम निष्पादित करते हैं जिसमें IMS DL / I मॉड्यूल शामिल होते हैं। तब अनुप्रयोग प्रोग्राम द्वारा ट्रिगर कॉल अनुरोध IMS मॉड्यूल द्वारा निष्पादित किए जाते हैं।

IMS सेवाएँ

निम्नलिखित IMS सेवाओं का उपयोग एप्लिकेशन प्रोग्राम द्वारा किया जाता है -

  • डेटाबेस रिकॉर्ड तक पहुँचना
  • आईएमएस आदेश जारी करना
  • आईएमएस सेवा कॉल जारी करना
  • चौकी कॉल
  • सिंक कॉल
  • ऑनलाइन उपयोगकर्ता टर्मिनलों से संदेश भेजना या प्राप्त करना

हम IMS डेटाबेस के साथ संवाद करने के लिए COBOL एप्लिकेशन प्रोग्राम के अंदर DL / I कॉल शामिल करते हैं। डेटाबेस तक पहुँचने के लिए हम COBOL प्रोग्राम में निम्नलिखित DL / I स्टेटमेंट का उपयोग करते हैं -

  • प्रवेश विवरण
  • Goback कथन
  • कॉल स्टेटमेंट

प्रवेश विवरण

इसका उपयोग DLB / I से COBOL प्रोग्राम के लिए नियंत्रण पास करने के लिए किया जाता है। यहाँ प्रवेश विवरण का वाक्य विन्यास है -

ENTRY 'DLITCBL' USING pcb-name1
                     [pcb-name2]

उपरोक्त कथन में कोडित है Procedure Divisionएक COBOL कार्यक्रम का। हमें COBOL कार्यक्रम में प्रवेश विवरण के विवरण में जाना चाहिए -

  • बैच इनिशियलाइज़ेशन मॉड्यूल एप्लिकेशन प्रोग्राम को ट्रिगर करता है और इसके नियंत्रण में निष्पादित होता है।

  • DL / I आवश्यक नियंत्रण ब्लॉक और मॉड्यूल और एप्लिकेशन प्रोग्राम को लोड करता है, और नियंत्रण एप्लिकेशन प्रोग्राम को दिया जाता है।

  • DLITCBL का मतलब है DL/I to COBOL। एंट्री स्टेटमेंट का उपयोग प्रोग्राम में एंट्री पॉइंट को परिभाषित करने के लिए किया जाता है।

  • जब हम COBOL में सब-प्रोग्राम कहते हैं, तो इसका पता भी दिया जाता है। इसी तरह, जब DL / I एप्लिकेशन प्रोग्राम को नियंत्रण देता है, तो यह प्रोग्राम के PSB में परिभाषित प्रत्येक पीसीबी का पता भी प्रदान करता है।

  • एप्लिकेशन प्रोग्राम में उपयोग किए जाने वाले सभी पीसीबी को अंदर परिभाषित किया जाना चाहिए Linkage Section COBOL प्रोग्राम क्योंकि PCB एप्लीकेशन प्रोग्राम के बाहर रहता है।

  • लिंकेज अनुभाग के अंदर पीसीबी की परिभाषा को कहा जाता है PCB Mask

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

Goback कथन

इसका उपयोग नियंत्रण वापस IMS नियंत्रण प्रोग्राम को पास करने के लिए किया जाता है। निम्नलिखित गोबाक कथन का वाक्य विन्यास है -

GOBACK

नीचे सूचीबद्ध बुनियादी बिंदु हैं जो गोबैक स्टेटमेंट के बारे में ध्यान देने योग्य हैं -

  • GOBACK को एप्लिकेशन प्रोग्राम के अंत में कोडित किया जाता है। यह कार्यक्रम से DL / I पर नियंत्रण लौटाता है।

  • हमें STOP RUN का उपयोग नहीं करना चाहिए क्योंकि यह ऑपरेटिंग सिस्टम पर नियंत्रण लौटाता है। यदि हम STOP RUN का उपयोग करते हैं, तो DL / I को कभी भी अपने समाप्त होने वाले कार्यों को करने का मौका नहीं मिलता है। इसीलिए, DL / I एप्लिकेशन प्रोग्राम में, Goback स्टेटमेंट का उपयोग किया जाता है।

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

कॉल स्टेटमेंट

कॉल स्टेटमेंट का उपयोग DL / I सेवाओं के लिए अनुरोध करने के लिए किया जाता है, जैसे IMS डेटाबेस पर कुछ संचालन निष्पादित करना। यहाँ कॉल स्टेटमेंट का सिंटैक्स है -

CALL 'CBLTDLI' USING DLI Function Code
                        PCB Mask
                        Segment I/O Area
                        [Segment Search Arguments]

ऊपर दिया गया सिंटैक्स उन मापदंडों को दिखाता है जिनका उपयोग आप कॉल स्टेटमेंट के साथ कर सकते हैं। हम निम्नलिखित तालिका में उनमें से प्रत्येक पर चर्चा करेंगे -

क्र.सं. पैरामीटर और विवरण
1

DLI Function Code

प्रदर्शन किए जाने वाले DL / I फ़ंक्शन को पहचानता है। यह तर्क I / O ऑपरेशन का वर्णन करने वाले चार वर्ण फ़ील्ड का नाम है।

2

PCB Mask

लिंकेज अनुभाग के अंदर पीसीबी परिभाषा को पीसीबी मास्क कहा जाता है। उनका उपयोग प्रवेश विवरण में किया जाता है। कोई चयन, ASSIGN, OPEN, या CLOSE स्टेटमेंट की आवश्यकता नहीं है।

3

Segment I/O Area

एक इनपुट / आउटपुट कार्य क्षेत्र का नाम। यह एप्लिकेशन प्रोग्राम का एक क्षेत्र है जिसमें DL / I एक अनुरोधित सेगमेंट डालता है।

4

Segment Search Arguments

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

नीचे दिए गए कॉल स्टेटमेंट के बारे में ध्यान देने योग्य बिंदु हैं -

  • CBLTDLI का मतलब है COBOL to DL/I। यह एक इंटरफ़ेस मॉड्यूल का नाम है जो आपके प्रोग्राम के ऑब्जेक्ट मॉड्यूल के साथ संपादित लिंक है।

  • प्रत्येक DL / I कॉल के बाद, DLI PCB में एक स्टेटस कोड स्टोर करता है। प्रोग्राम इस कोड का उपयोग यह निर्धारित करने के लिए कर सकता है कि कॉल सफल हुआ या विफल।

उदाहरण

COBOL की अधिक समझ के लिए, आप हमारे COBOL ट्यूटोरियल के माध्यम से यहाँ जा सकते हैं  । निम्न उदाहरण एक COBOL प्रोग्राम की संरचना दिखाता है जो IMS डेटाबेस और DL / I कॉल का उपयोग करता है। हम आगामी अध्यायों में उदाहरण में उपयोग किए गए प्रत्येक पैरामीटर के बारे में विस्तार से चर्चा करेंगे।

IDENTIFICATION DIVISION.
PROGRAM-ID. TEST1.
DATA DIVISION.
WORKING-STORAGE SECTION.
01 DLI-FUNCTIONS.
   05 DLI-GU        PIC X(4)    VALUE 'GU  '.
   05 DLI-GHU       PIC X(4)    VALUE 'GHU '.
   05 DLI-GN        PIC X(4)    VALUE 'GN  '.
   05 DLI-GHN       PIC X(4)    VALUE 'GHN '.
   05 DLI-GNP       PIC X(4)    VALUE 'GNP '.
   05 DLI-GHNP      PIC X(4)    VALUE 'GHNP'.
   05 DLI-ISRT      PIC X(4)    VALUE 'ISRT'.
   05 DLI-DLET      PIC X(4)    VALUE 'DLET'.
   05 DLI-REPL      PIC X(4)    VALUE 'REPL'.
   05 DLI-CHKP      PIC X(4)    VALUE 'CHKP'.
   05 DLI-XRST      PIC X(4)    VALUE 'XRST'.
   05 DLI-PCB       PIC X(4)    VALUE 'PCB '.
01  SEGMENT-I-O-AREA        PIC X(150).
LINKAGE SECTION.
01  STUDENT-PCB-MASK.
   05 STD-DBD-NAME              PIC X(8).
   05 STD-SEGMENT-LEVEL         PIC XX.
   05 STD-STATUS-CODE           PIC XX.
   05 STD-PROC-OPTIONS          PIC X(4).
   05 FILLER                    PIC S9(5) COMP.
   05 STD-SEGMENT-NAME          PIC X(8).
   05 STD-KEY-LENGTH            PIC S9(5) COMP.
   05 STD-NUMB-SENS-SEGS        PIC S9(5) COMP.
   05 STD-KEY                   PIC X(11).
PROCEDURE DIVISION.
ENTRY 'DLITCBL' USING STUDENT-PCB-MASK.
A000-READ-PARA.
110-GET-INVENTORY-SEGMENT.
   CALL ‘CBLTDLI’ USING DLI-GN
                  STUDENT-PCB-MASK
                  SEGMENT-I-O-AREA.
GOBACK.

DL / I फ़ंक्शन पहला पैरामीटर है जिसका उपयोग DL / I कॉल में किया जाता है। यह फ़ंक्शन बताता है कि IMS DL / I कॉल द्वारा IMS डेटाबेस पर कौन सा ऑपरेशन होने वाला है। DL / I फ़ंक्शन का सिंटैक्स निम्नानुसार है -

01 DLI-FUNCTIONS.
   05 DLI-GU        PIC X(4)    VALUE 'GU  '.
   05 DLI-GHU       PIC X(4)    VALUE 'GHU '.
   05 DLI-GN        PIC X(4)    VALUE 'GN  '.
   05 DLI-GHN       PIC X(4)    VALUE 'GHN '.
   05 DLI-GNP       PIC X(4)    VALUE 'GNP '.
   05 DLI-GHNP      PIC X(4)    VALUE 'GHNP'.
   05 DLI-ISRT      PIC X(4)    VALUE 'ISRT'.
   05 DLI-DLET      PIC X(4)    VALUE 'DLET'.
   05 DLI-REPL      PIC X(4)    VALUE 'REPL'.
   05 DLI-CHKP      PIC X(4)    VALUE 'CHKP'.
   05 DLI-XRST      PIC X(4)    VALUE 'XRST'.
   05 DLI-PCB       PIC X(4)    VALUE 'PCB '.

यह सिंटैक्स निम्नलिखित प्रमुख बिंदुओं का प्रतिनिधित्व करता है -

  • इस पैरामीटर के लिए, हम फ़ंक्शन कोड को स्टोर करने के लिए स्टोरेज फ़ील्ड के रूप में कोई भी चार-वर्ण नाम प्रदान कर सकते हैं।

  • DLB / I फ़ंक्शन पैरामीटर को COBOL प्रोग्राम के कार्यशील भंडारण अनुभाग में कोडित किया गया है।

  • DL / I फ़ंक्शन को निर्दिष्ट करने के लिए, प्रोग्रामर को DL / I कॉल में DLI-GU जैसे 05 स्तर के डेटा नामों में से एक को कोड करने की आवश्यकता होती है, क्योंकि COBOL एक कॉल विवरण पर कोड शाब्दिकों को कोड करने की अनुमति नहीं देता है।

  • DL / I फ़ंक्शन को तीन श्रेणियों में विभाजित किया गया है: गेट, अपडेट और अन्य फ़ंक्शन। आइए हम उनमें से प्रत्येक पर विस्तार से चर्चा करें।

कार्य प्राप्त करें

प्राप्त फ़ंक्शन किसी भी प्रोग्रामिंग भाषा द्वारा समर्थित रीड ऑपरेशन के समान हैं। Get फ़ंक्शन का उपयोग IMS DL / I डेटाबेस से सेगमेंट लाने के लिए किया जाता है। निम्नलिखित कार्य IMS DB में उपयोग किए जाते हैं -

  • अनोखा हो जाओ
  • अगले जाओ
  • माता-पिता के भीतर अगले जाओ
  • अद्वितीय पकड़ो
  • अगला पकड़ें
  • माता-पिता के भीतर अगले पकड़ो

आइए DL / I फ़ंक्शन कॉल को समझने के लिए निम्नलिखित IMS डेटाबेस संरचना पर विचार करें -

अनोखा हो जाओ

Function GU ’कोड का उपयोग गेट यूनीक फंक्शन के लिए किया जाता है। यह COBOL में रैंडम रीड स्टेटमेंट के समान काम करता है। इसका उपयोग क्षेत्र मूल्यों के आधार पर एक विशेष खंड घटना लाने के लिए किया जाता है। खंड खोज तर्कों का उपयोग करके क्षेत्र मूल्यों को प्रदान किया जा सकता है। GU कॉल का सिंटैक्स निम्नानुसार है -

CALL 'CBLTDLI' USING DLI-GU
                     PCB Mask
                     Segment I/O Area
                     [Segment Search Arguments]

यदि आप COBOL कार्यक्रम में सभी मापदंडों के लिए उचित मूल्य प्रदान करके उपरोक्त कॉल स्टेटमेंट को निष्पादित करते हैं, तो आप डेटाबेस से खंड I / O क्षेत्र में खंड को पुनः प्राप्त कर सकते हैं। उपरोक्त उदाहरण में, यदि आप लाइब्रेरी, पत्रिका और स्वास्थ्य के क्षेत्र मूल्य प्रदान करते हैं, तो आपको स्वास्थ्य खंड की वांछित घटना मिलती है।

अगले जाओ

'GN' कोड का उपयोग गेट नेक्स्ट फंक्शन के लिए किया जाता है। यह COBOL में पढ़े गए अगले कथन के समान है। यह एक अनुक्रम में खंड घटनाओं लाने के लिए प्रयोग किया जाता है। डेटा खंड घटनाओं तक पहुँचने के लिए पूर्वनिर्धारित पैटर्न पदानुक्रम नीचे है, फिर दाएं से बाएं। GN कॉल का सिंटैक्स इस प्रकार है -

CALL 'CBLTDLI' USING DLI-GN
                     PCB Mask
                     Segment I/O Area
                     [Segment Search Arguments]

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

माता-पिता के भीतर अगले जाओ

'GNP' कोड का उपयोग पेरेंट के भीतर गेट नेक्स्ट के लिए किया जाता है। इस फ़ंक्शन का उपयोग किसी स्थापित पैरेंट सेगमेंट के अधीनस्थ अनुक्रम में खंडों की घटनाओं को पुनः प्राप्त करने के लिए किया जाता है। GNP कॉल का सिंटैक्स इस प्रकार है -

CALL 'CBLTDLI' USING DLI-GNP
                     PCB Mask
                     Segment I/O Area
                     [Segment Search Arguments]

अद्वितीय पकड़ो

'GHU' कोड का उपयोग गेट होल्ड यूनिक के लिए किया जाता है। होल्ड फ़ंक्शन निर्दिष्ट करता है कि हम पुनर्प्राप्ति के बाद खंड को अपडेट करने जा रहे हैं। गेट होल्ड यूनीक फ़ंक्शन गेट यूनिक कॉल से मेल खाता है। नीचे एक GHU कॉल का सिंटैक्स दिया गया है -

CALL 'CBLTDLI' USING DLI-GHU
                     PCB Mask
                     Segment I/O Area
                     [Segment Search Arguments]

अगला पकड़ें

'GHN' कोड का इस्तेमाल गेट होल्ड नेक्स्ट के लिए किया जाता है। होल्ड फ़ंक्शन निर्दिष्ट करता है कि हम पुनर्प्राप्ति के बाद खंड को अपडेट करने जा रहे हैं। गेट होल्ड नेक्स्ट फ़ंक्शन गेट नेक्स्ट कॉल से मेल खाता है। नीचे एक GHN कॉल का सिंटैक्स दिया गया है -

CALL 'CBLTDLI' USING DLI-GHN
                     PCB Mask
                     Segment I/O Area
                     [Segment Search Arguments]

माता-पिता के भीतर अगले पकड़ो

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

CALL 'CBLTDLI' USING DLI-GHNP
                     PCB Mask
                     Segment I/O Area
                     [Segment Search Arguments]

फ़ंक्शंस अपडेट करें

अपडेट फ़ंक्शन किसी अन्य प्रोग्रामिंग भाषा में संचालन को फिर से लिखने या सम्मिलित करने के समान हैं। IMS DL / I डेटाबेस में सेगमेंट को अपडेट करने के लिए अपडेट फ़ंक्शन का उपयोग किया जाता है। अपडेट फ़ंक्शन का उपयोग करने से पहले, खंड घटना के लिए होल्ड क्लॉज के साथ एक सफल कॉल होना चाहिए। निम्नलिखित अद्यतन कार्य IMS DB में उपयोग किए जाते हैं -

  • Insert
  • Delete
  • Replace

डालने

इंसर्ट फंक्शन के लिए 'ISRT' कोड का इस्तेमाल किया जाता है। ISRT फ़ंक्शन का उपयोग डेटाबेस में एक नए सेगमेंट को जोड़ने के लिए किया जाता है। इसका उपयोग मौजूदा डेटाबेस को बदलने या नए डेटाबेस को लोड करने के लिए किया जाता है। नीचे एक ISRT कॉल का सिंटैक्स दिया गया है -

CALL 'CBLTDLI' USING DLI-ISRT
                     PCB Mask
                     Segment I/O Area
                     [Segment Search Arguments]

हटाएं

'DLET' कोड का उपयोग डिलीट फंक्शन के लिए किया जाता है। इसका उपयोग IMS DL / I डेटाबेस से एक खंड को निकालने के लिए किया जाता है। नीचे एक DLET कॉल का सिंटैक्स दिया गया है -

CALL 'CBLTDLI' USING DLI-DLET
                     PCB Mask
                     Segment I/O Area
                     [Segment Search Arguments]

बदलने के

'REPL' कोड का उपयोग अभिभावक के भीतर गेट होल्ड नेक्स्ट के लिए किया जाता है। बदलें फ़ंक्शन का उपयोग IMS DL / I डेटाबेस में एक सेगमेंट को बदलने के लिए किया जाता है। नीचे एक REPL कॉल का सिंटैक्स दिया गया है -

CALL 'CBLTDLI' USING DLI-REPL
                     PCB Mask
                     Segment I/O Area
                     [Segment Search Arguments]

अन्य कार्य

निम्नलिखित अन्य कार्य IMS DL / I कॉल में उपयोग किए जाते हैं -

  • Checkpoint
  • Restart
  • PCB

जांच की चौकी

चेकपॉइंट फ़ंक्शन के लिए 'CHKP' कोड का उपयोग किया जाता है। इसका उपयोग IMS की पुनर्प्राप्ति सुविधाओं में किया जाता है। नीचे एक CHKP कॉल का सिंटैक्स दिया गया है -

CALL 'CBLTDLI' USING DLI-CHKP
                     PCB Mask
                     Segment I/O Area
                     [Segment Search Arguments]

पुनर्प्रारंभ करें

'XRST' कोड का उपयोग रीस्टार्ट फ़ंक्शन के लिए किया जाता है। इसका उपयोग IMS की पुनरारंभ सुविधाओं में किया जाता है। नीचे एक XRST कॉल का सिंटैक्स दिया गया है -

CALL 'CBLTDLI' USING DLI-XRST
                     PCB Mask
                     Segment I/O Area
                     [Segment Search Arguments]

पीसीबी

पीसीबी फ़ंक्शन का उपयोग IMS DL / I डेटाबेस में CICS कार्यक्रमों में किया जाता है। नीचे एक पीसीबी कॉल का सिंटैक्स दिया गया है -

CALL 'CBLTDLI' USING DLI-PCB
                     PCB Mask
                     Segment I/O Area
                     [Segment Search Arguments]

आप पुनर्प्राप्ति अध्याय में इन कार्यों के बारे में अधिक जानकारी पा सकते हैं।

पीसीबी प्रोग्राम कम्युनिकेशन ब्लॉक के लिए है। PCB मास्क DL / I कॉल में प्रयुक्त दूसरा पैरामीटर है। इसे लिंकेज सेक्शन में घोषित किया जाता है। नीचे एक पीसीबी मास्क का सिंटैक्स दिया गया है -

01 PCB-NAME.
   05 DBD-NAME         PIC X(8).
   05 SEG-LEVEL        PIC XX.
   05 STATUS-CODE      PIC XX.
   05 PROC-OPTIONS     PIC X(4).
   05 RESERVED-DLI     PIC S9(5).
   05 SEG-NAME         PIC X(8).
   05 LENGTH-FB-KEY    PIC S9(5).
   05 NUMB-SENS-SEGS   PIC S9(5).
   05 KEY-FB-AREA      PIC X(n).

यहां ध्यान देने योग्य मुख्य बातें हैं -

  • प्रत्येक डेटाबेस के लिए, DL / I भंडारण का एक क्षेत्र रखता है जिसे प्रोग्राम कम्युनिकेशन ब्लॉक के रूप में जाना जाता है। यह उन डेटाबेस के बारे में जानकारी संग्रहीत करता है जो एप्लिकेशन प्रोग्राम के अंदर एक्सेस होते हैं।

  • ENTRY स्टेटमेंट, लिंकेज अनुभाग में PCB मास्क और प्रोग्राम के PSB के भीतर PCB के बीच संबंध बनाता है। DL / I कॉल में प्रयुक्त पीसीबी मास्क बताता है कि ऑपरेशन के लिए किस डेटाबेस का उपयोग करना है।

  • आप मान सकते हैं कि यह COBOL READ स्टेटमेंट में फाइल नाम या COBOL राइट स्टेटमेंट में रिकॉर्ड नाम के समान है। कोई चयन, ASSIGN, OPEN, या CLOSE स्टेटमेंट की आवश्यकता नहीं है।

  • प्रत्येक DL / I कॉल के बाद, DL / I पीसीबी में एक स्थिति कोड संग्रहीत करता है और प्रोग्राम उस कोड का उपयोग यह निर्धारित करने के लिए कर सकता है कि कॉल सफल हुई या विफल।

पीसीबी का नाम

नोट करने के लिए अंक -

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

  • PCB Name का उपयोग प्रोग्राम स्टेटमेंट में किया जाता है।

  • पीसीबी नाम पीसीबी में एक क्षेत्र नहीं है।

DBD नाम

नोट करने के लिए अंक -

  • DBD नाम में वर्ण डेटा होता है। यह आठ बाइट्स लंबा होता है।

  • पीसीबी में पहला क्षेत्र संसाधित किए जा रहे डेटाबेस का नाम है और यह एक विशेष डेटाबेस से जुड़े डेटाबेस विवरणों के पुस्तकालय से डीबीडी नाम प्रदान करता है।

खंड स्तर

नोट करने के लिए अंक -

  • सेगमेंट स्तर को सेगमेंट पदानुक्रम स्तर संकेतक के रूप में जाना जाता है। इसमें वर्ण डेटा होता है और यह दो बाइट्स लंबा होता है।

  • एक खंड स्तर फ़ील्ड उस खंड के स्तर को संग्रहीत करता है जिसे संसाधित किया गया था। जब किसी खंड को सफलतापूर्वक पुनर्प्राप्त किया जाता है, तो पुनर्प्राप्त खंड की स्तर संख्या यहां संग्रहीत की जाती है।

  • खंड खंड फ़ील्ड का मान कभी भी 15 से अधिक नहीं होता है क्योंकि यह DL / I डेटाबेस में अनुमत अधिकतम स्तर है।

स्थिति का कोड

नोट करने के लिए अंक -

  • स्थिति कोड फ़ील्ड में वर्ण डेटा के दो बाइट्स होते हैं।

  • स्टेटस कोड में DL / I स्टेटस कोड होता है।

  • जब DL / I सफलतापूर्वक कॉल के प्रसंस्करण को पूरा करता है तो स्पेस को स्थिति कोड फ़ील्ड में ले जाया जाता है।

  • गैर-स्थान मान इंगित करते हैं कि कॉल सफल नहीं थी।

  • स्थिति कोड GB एंड-ऑफ़-फ़ाइल इंगित करता है और स्थिति कोड GE इंगित करता है कि अनुरोधित खंड नहीं मिला है।

प्रोक विकल्प

नोट करने के लिए अंक -

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

  • एक प्रसंस्करण विकल्प क्षेत्र इंगित करता है कि डेटाबेस पर किस तरह का प्रसंस्करण कार्यक्रम करने के लिए अधिकृत है।

आरक्षित डीएल / आई

नोट करने के लिए अंक -

  • आरक्षित DL / I को IMS के आरक्षित क्षेत्र के रूप में जाना जाता है। यह चार बाइट्स बाइनरी डेटा स्टोर करता है।

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

खंड का नाम

नोट करने के लिए अंक -

  • SEG नाम को खंड नाम प्रतिक्रिया क्षेत्र के रूप में जाना जाता है। इसमें वर्ण डेटा के 8 बाइट्स होते हैं।

  • प्रत्येक डीएल / आई कॉल के बाद इस क्षेत्र में खंड का नाम संग्रहीत किया जाता है।

लंबाई FB कुंजी

नोट करने के लिए अंक -

  • लंबाई एफबी कुंजी को कुंजी प्रतिक्रिया क्षेत्र की लंबाई के रूप में जाना जाता है। यह बाइनरी डेटा के चार बाइट्स को स्टोर करता है।

  • इस फ़ील्ड का उपयोग पिछली कॉल के दौरान संसाधित किए गए निम्नतम स्तर के सेगमेंट की लंबाई की रिपोर्ट करने के लिए किया जाता है।

  • इसका उपयोग प्रमुख प्रतिक्रिया क्षेत्र के साथ किया जाता है।

संवेदनशीलता सेगमेंट की संख्या

नोट करने के लिए अंक -

  • संवेदनशीलता खंडों की संख्या चार बाइट्स बाइनरी डेटा को स्टोर करती है।

  • यह निर्धारित करता है कि आवेदन कार्यक्रम किस स्तर तक संवेदनशील है। यह तार्किक डेटा संरचना में खंडों की संख्या का प्रतिनिधित्व करता है।

मुख्य प्रतिक्रिया क्षेत्र

नोट करने के लिए अंक -

  • मुख्य प्रतिक्रिया क्षेत्र एक पीसीबी से दूसरे में लंबाई में भिन्न होता है।

  • इसमें सबसे लंबी संभव संक्षिप्त कुंजी होती है जिसे प्रोग्राम के डेटाबेस के दृश्य के साथ उपयोग किया जा सकता है।

  • डेटाबेस ऑपरेशन के बाद, DL / I इस क्षेत्र में संसाधित सबसे निचले स्तर के खंड की संक्षिप्त कुंजी लौटाता है, और यह कुंजी की लंबाई प्रतिक्रिया क्षेत्र में कुंजी की लंबाई लौटाता है।

SSA का मतलब सेगमेंट सर्च आर्ग्युमेंट्स से है। एसएसए का उपयोग उस खंड घटना की पहचान करने के लिए किया जाता है। यह एक वैकल्पिक पैरामीटर है। हम आवश्यकता के आधार पर किसी भी एसएसए को शामिल कर सकते हैं। दो प्रकार के एसएसए हैं -

  • अयोग्य एसएसए
  • योग्य एसएसए

अयोग्य एसएसए

एक अयोग्य एसएसए कॉल के अंदर उपयोग किए जा रहे सेगमेंट का नाम प्रदान करता है। नीचे दिए गए एक अयोग्य SSA का वाक्य विन्यास है -

01 UNQUALIFIED-SSA.
   05  SEGMENT-NAME  PIC X(8).
   05  FILLER        PIC X     VALUE SPACE.

अयोग्य एसएसए के मुख्य बिंदु इस प्रकार हैं -

  • एक बुनियादी अयोग्य एसएसए 9 बाइट्स लंबा है।

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

  • अंतिम बाइट में हमेशा स्थान होता है।

  • SSA के प्रकार को निर्धारित करने के लिए DL / I अंतिम बाइट का उपयोग करता है।

  • किसी विशेष सेगमेंट तक पहुंचने के लिए, सेगमेंट के नाम को NAME फ़ील्ड में ले जाएँ।

निम्नलिखित चित्र अयोग्य और योग्य SSAs की संरचनाओं को दिखाते हैं -

योग्य एसएसए

एक योग्य एसएसए एक खंड के विशिष्ट डेटाबेस घटना के साथ खंड प्रकार प्रदान करता है। नीचे दिए गए योग्य SSA का सिंटैक्स है -

01 QUALIFIED-SSA.
   05  SEGMENT-NAME  PIC X(8).
   05  FILLER        PIC X(01)      VALUE '('.
   05  FIELD-NAME    PIC X(8).
   05  REL-OPR       PIC X(2).
   05  SEARCH-VALUE  PIC X(n).
   05  FILLER        PIC X(n+1) VALUE ')'.

योग्य SSA के मुख्य बिंदु इस प्रकार हैं -

  • एक योग्य SSA के पहले 8 बाइट्स प्रसंस्करण के लिए उपयोग किए जा रहे सेगमेंट का नाम रखते हैं।

  • नौवां बाइट एक बाएं कोष्ठक है '('।

  • दसवीं स्थिति से शुरू होने वाले अगले 8 बाइट्स क्षेत्र का नाम निर्दिष्ट करते हैं जिसे हम खोजना चाहते हैं।

  • क्षेत्र के नाम के बाद, 18 वें और 19 वें स्थान पर, हम दो-चरित्र संबंधपरक ऑपरेटर कोड निर्दिष्ट करते हैं।

  • फिर हम फ़ील्ड मान निर्दिष्ट करते हैं और अंतिम बाइट में, एक सही कोष्ठक ') है।'

निम्न तालिका एक योग्य SSA में प्रयुक्त रिलेशनल ऑपरेटरों को दिखाती है।

संबंधित ऑपरेटर प्रतीक विवरण
eq के = बराबरी का
NE ~ = ˜ बराबर नहीं
जीटी > से अधिक
जीई > = से बड़ा या बराबर
लेफ्टिनेंट << से कम
LE <= इससे कम या इसके बराबर

कमांड कोड

डीएल / आई कॉल की कार्यक्षमता बढ़ाने के लिए कमांड कोड का उपयोग किया जाता है। कमांड कोड डीएल / आई कॉल की संख्या को कम करते हैं, जिससे प्रोग्राम सरल हो जाते हैं। साथ ही, यह कॉल की संख्या कम होने के कारण प्रदर्शन में सुधार करता है। निम्न छवि दिखाती है कि कैसे अयोग्य और योग्य SSAs में कमांड कोड का उपयोग किया जाता है -

कमांड कोड के प्रमुख बिंदु इस प्रकार हैं -

  • कमांड कोड का उपयोग करने के लिए, एसएसए के 9 वें स्थान पर तारांकन निर्दिष्ट करें जैसा कि ऊपर की छवि में दिखाया गया है।

  • कमांड कोड को दसवें स्थान पर कोडित किया गया है।

  • 10 वें स्थान से, डीएल / मैं सभी वर्णों को कमांड कोड मानता है जब तक कि यह एक योग्य एसएसए के लिए एक अयोग्य एसएसए और एक बाएं कोष्ठक के लिए एक स्थान का सामना नहीं करता है।

निम्न तालिका SSA में प्रयुक्त कमांड कोड की सूची दिखाती है -

कमांड कोड विवरण
सी संबंधित कुंजी
पाथ कॉल
एफ पहली घटना
एल अंतिम घटना
एन पाथ कॉल इग्नोर
पी पेरेंटेज सेट करें
क्यू एंक्यू सेगमेंट
यू इस स्तर पर स्थिति बनाए रखें
वी इस और सभी स्तरों पर स्थिति बनाए रखें
- नल कमांड कोड

एकाधिक योग्यताएँ

कई योग्यता के मूल बिंदु इस प्रकार हैं -

  • तुलना के लिए दो या दो से अधिक योग्यता या क्षेत्रों का उपयोग करने की आवश्यकता होने पर कई योग्यताएं आवश्यक हैं।

  • हम बूलियन ऑपरेटरों जैसे AND और OR का उपयोग दो या अधिक योग्यताओं को जोड़ने के लिए करते हैं।

  • जब हम किसी एकल क्षेत्र के लिए संभावित मानों की श्रेणी के आधार पर किसी सेगमेंट को संसाधित करना चाहते हैं तो कई योग्यताओं का उपयोग किया जा सकता है।

नीचे दिए गए एकाधिक योग्यता का सिंटैक्स है -

01 QUALIFIED-SSA.
   05  SEGMENT-NAME  PIC X(8).
   05  FILLER        PIC X(01)      VALUE '('.
   05  FIELD-NAME1   PIC X(8).
   05  REL-OPR       PIC X(2).
   05  SEARCH-VALUE1 PIC X(m).
   05  MUL-QUAL      PIC X      VALUE '&'.
   05  FIELD-NAME2   PIC X(8).
   05  REL-OPR       PIC X(2).
   05  SEARCH-VALUE2 PIC X(n).
   05  FILLER        PIC X(n+1) VALUE ')'.

MUL-QUAL, MULtiple QUALIification की एक छोटी अवधि है जिसमें हम बूलियन ऑपरेटरों जैसे AND या OR प्रदान कर सकते हैं।

IMS DL / I कॉल में उपयोग किए जाने वाले विभिन्न डेटा पुनर्प्राप्ति विधियाँ निम्नानुसार हैं -

  • जीयू कॉल
  • जीएन कॉल
  • कमांड कोड का उपयोग करना
  • एकाधिक प्रसंस्करण

आइए, डेटा पुनर्प्राप्ति फ़ंक्शन कॉल को समझने के लिए निम्नलिखित IMS डेटाबेस संरचना पर विचार करें -

जीयू कॉल

जीयू कॉल की बुनियादी बातें इस प्रकार हैं -

  • जीयू कॉल को गेट यूनिक कॉल के रूप में जाना जाता है। इसका उपयोग यादृच्छिक प्रसंस्करण के लिए किया जाता है।

  • यदि कोई एप्लिकेशन डेटाबेस को नियमित रूप से अपडेट नहीं करता है या यदि डेटाबेस अपडेट की संख्या कम है, तो हम यादृच्छिक प्रसंस्करण का उपयोग करते हैं।

  • जीयू कॉल का उपयोग आगे की अनुक्रमिक पुनर्प्राप्ति के लिए एक विशेष स्थान पर सूचक को रखने के लिए किया जाता है।

  • जीयू कॉल पिछले कॉल द्वारा स्थापित पॉइंटर स्थिति से स्वतंत्र हैं।

  • जीयू कॉल प्रोसेसिंग कॉल स्टेटमेंट में सप्लाई किए जाने वाले अनूठे प्रमुख क्षेत्रों पर आधारित है।

  • यदि हम एक महत्वपूर्ण फ़ील्ड की आपूर्ति करते हैं जो अद्वितीय नहीं है, तो DL / I कुंजी फ़ील्ड की पहली खंड घटना लौटाता है।

CALL 'CBLTDLI' USING DLI-GU
                     PCB-NAME
                     IO-AREA
                     LIBRARY-SSA
                     BOOKS-SSA
                     ENGINEERING-SSA
                     IT-SSA

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

गुजरात कॉल विचार

यदि हम कॉल में योग्य SSAs का पूरा सेट प्रदान नहीं करते हैं, तो DL / I निम्नलिखित तरीके से काम करता है -

  • जब हम GU कॉल में एक अयोग्य SSA का उपयोग करते हैं, तो DL / I डेटाबेस में आपके द्वारा निर्दिष्ट मानदंडों को पूरा करता है।

  • जब हम कोई एसएसए के बिना जीयू कॉल जारी करते हैं, तो डीएल / I डेटाबेस में रूट सेगमेंट की पहली घटना देता है।

  • यदि मध्यवर्ती स्तरों पर कुछ SSAs कॉल में उल्लेख नहीं किया जाता है, तो DL / I या तो स्थापित स्थिति का उपयोग करता है या खंड के लिए अयोग्य SSA के डिफ़ॉल्ट मान का उपयोग करता है।

स्थिति कोड

निम्न तालिका जीयू कॉल के बाद प्रासंगिक स्थिति कोड दिखाती है -

S.No स्थिति कोड और विवरण
1

Spaces

सफल कॉल

2

GE

डीएल / मुझे एक खंड नहीं मिला जो कॉल में निर्दिष्ट मानदंडों को पूरा करता हो

जीएन कॉल

जीएन कॉल की बुनियादी बातें इस प्रकार हैं -

  • जीएन कॉल को गेट नेक्स्ट कॉल के रूप में जाना जाता है। इसका उपयोग मूल अनुक्रमिक प्रसंस्करण के लिए किया जाता है।

  • डेटाबेस में पॉइंटर की प्रारंभिक स्थिति पहले डेटाबेस रिकॉर्ड के रूट सेगमेंट से पहले है।

  • एक सफल GN कॉल के बाद, डेटाबेस पॉइंटर पोजिशन अनुक्रम में अगले सेगमेंट की घटना से पहले है।

  • जीएन कॉल डेटाबेस से पिछले कॉल द्वारा स्थापित स्थिति से शुरू होता है।

  • यदि कोई GN कॉल अयोग्य है, तो यह इसके प्रकार की परवाह किए बिना, श्रेणीबद्ध अनुक्रम में डेटाबेस में अगले खंड की घटना देता है।

  • यदि GN कॉल में SSAs शामिल हैं, तो DL / I केवल उन खंडों को पुनः प्राप्त करता है जो सभी निर्दिष्ट SSAs की आवश्यकताओं को पूरा करते हैं।

CALL 'CBLTDLI' USING DLI-GN
                     PCB-NAME
                     IO-AREA
                     BOOKS-SSA

उपरोक्त उदाहरण से पता चलता है कि हम एक जीएन कॉल जारी करते हैं जो रिकॉर्ड को क्रमिक रूप से पढ़ने के लिए शुरुआती स्थिति प्रदान करता है। यह BOOKS खंड की पहली घटना है।

स्थिति कोड

निम्न तालिका एक जीएन कॉल के बाद प्रासंगिक स्थिति कोड दिखाती है -

S.No स्थिति कोड और विवरण
1

Spaces

सफल कॉल

2

GE

डीएल / मुझे एक खंड नहीं मिला जो कॉल में निर्दिष्ट मानदंडों को पूरा करता हो।

3

GA

एक अयोग्य जीएन कॉल खंड को प्राप्त करने के लिए डेटाबेस पदानुक्रम में एक स्तर ऊपर ले जाता है।

4

GB

डेटाबेस का अंत पहुँच गया है और खंड नहीं मिला।

GK

एक अयोग्य जीएन कॉल एक विशेष प्रकार के एक खंड को लाने की कोशिश करता है, जो केवल पुनर्प्राप्त किया जाता है, लेकिन एक ही श्रेणीबद्ध स्तर पर रहता है।

कमांड कोड

एक खंड घटना लाने के लिए कॉल के साथ कमांड कोड का उपयोग किया जाता है। कॉल के साथ उपयोग किए जाने वाले विभिन्न कमांड कोड नीचे चर्चा किए गए हैं।

एफ कमांड कोड

नोट करने के लिए अंक -

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

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

  • यदि हम GU कॉल के साथ एक एफ कमांड कोड निर्दिष्ट करते हैं, तो इसका कोई महत्व नहीं है, क्योंकि जीयू कॉल डिफ़ॉल्ट रूप से पहला खंड होता है।

एल कमांड कोड

नोट करने के लिए अंक -

  • जब एक कॉल में एक एल कमांड कोड निर्दिष्ट किया जाता है, तो कॉल सेगमेंट की अंतिम घटना को संसाधित करता है।

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

डी कमांड कोड

नोट करने के लिए अंक -

  • डी कमांड कोड का उपयोग एक एकल कॉल का उपयोग करके एक से अधिक खंडों को लाने के लिए किया जाता है।

  • आम तौर पर डीएल / मैं एक एसएसए में निर्दिष्ट सबसे निचले स्तर के खंड पर काम करता है, लेकिन कई मामलों में, हम अन्य स्तरों से भी डेटा चाहते हैं। उन मामलों में, हम डी कमांड कोड का उपयोग कर सकते हैं।

  • डी कमांड कोड सेगमेंट के पूरे पथ की आसान पुनर्प्राप्ति करता है।

C कमांड कोड

नोट करने के लिए अंक -

  • C कमांड कोड का उपयोग कुंजी को समाप्‍त करने के लिए किया जाता है।

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

निम्नलिखित उदाहरण सी कमांड कोड का उपयोग दिखाता है -

01 LOCATION-SSA.
   05 FILLER		     PIC X(11) VALUE ‘INLOCSEG*C(‘.
   05 LIBRARY-SSA      PIC X(5).
   05 BOOKS-SSA        PIC X(4).
   05 ENGINEERING-SSA  PIC X(6).
   05 IT-SSA           PIC X(3)
   05 FILLER		     PIC X	VALUE ‘)’.

CALL 'CBLTDLI' USING DLI-GU
                     PCB-NAME
                     IO-AREA
                     LOCATION-SSA

P कमांड कोड

नोट करने के लिए अंक -

  • जब हम GU या GN कॉल जारी करते हैं, तो DL / I सबसे कम स्तर के खंड में अपने पेरेंटेज की स्थापना करता है जिसे पुनर्प्राप्त किया जाता है।

  • यदि हम एक पी कमांड कोड शामिल करते हैं, तो डीएल / I पदानुक्रमित पथ में एक उच्च स्तर के खंड में अपने पेरेंटेज की स्थापना करता है।

यू कमांड कोड

नोट करने के लिए अंक -

  • जब एक यूएन कोड को जीएन कॉल में अयोग्य एसएसए में निर्दिष्ट किया जाता है, तो डीएल / I खंड की खोज को प्रतिबंधित करता है।

  • यदि यह एक योग्य एसएसए के साथ प्रयोग किया जाता है तो यू कमांड कोड को अनदेखा किया जाता है।

वी कमांड कोड

नोट करने के लिए अंक -

  • वी कमांड कोड यू कमांड कोड के समान काम करता है, लेकिन यह एक विशेष स्तर पर एक खंड की खोज को प्रतिबंधित करता है और पदानुक्रम से ऊपर के सभी स्तरों को।

  • योग्य एसएसए के साथ उपयोग किए जाने पर वी कमांड कोड को अनदेखा किया जाता है।

क्यू कमांड कोड

नोट करने के लिए अंक -

  • Q कमांड कोड का उपयोग आपके एप्लिकेशन प्रोग्राम के अनन्य उपयोग के लिए एक सेगमेंट को आरक्षित या आरक्षित करने के लिए किया जाता है।

  • क्यू कमांड कोड का उपयोग एक इंटरैक्टिव वातावरण में किया जाता है जहां एक और कार्यक्रम एक सेगमेंट में बदलाव कर सकता है।

एकाधिक प्रसंस्करण

एक प्रोग्राम में IMS डेटाबेस में कई पद हो सकते हैं जिन्हें कई प्रोसेसिंग के रूप में जाना जाता है। एकाधिक प्रसंस्करण दो तरीकों से किया जा सकता है -

  • एकाधिक पीसीबी
  • एकाधिक स्थिति

एकाधिक पीसीबी

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

एकाधिक स्थिति

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

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

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

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

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

सेकेंडरी इंडेक्सिंग का उपयोग तब किया जाता है जब हम किसी डेटाबेस को पूरी तरह से बिना कुंजी के उपयोग के बिना एक्सेस करना चाहते हैं या जब हम अनुक्रम प्राथमिक क्षेत्रों का उपयोग नहीं करना चाहते हैं।

सूचकांक सूचक खंड

DL / I सूचक को अनुक्रमित डेटाबेस के खंडों में एक अलग डेटाबेस में संग्रहीत करता है। इंडेक्स पॉइंटर सेगमेंट एकमात्र प्रकार का सेकेंडरी इंडेक्स है। इसके दो भाग हैं -

  • उपसर्ग तत्व
  • डेटा तत्व

उपसर्ग तत्व

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

डेटा तत्व

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

माध्यमिक अनुक्रमण के बारे में ध्यान देने योग्य मुख्य बातें इस प्रकार हैं -

  • सूचकांक स्रोत खंड और लक्ष्य स्रोत खंड समान होने की आवश्यकता नहीं है।

  • जब हम एक द्वितीयक सूचकांक स्थापित करते हैं, तो यह स्वचालित रूप से DL / I द्वारा बनाए रखा जाता है।

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

  • हमें अधिक माध्यमिक अनुक्रम नहीं बनाने चाहिए, क्योंकि वे DL / I पर अतिरिक्त प्रसंस्करण ओवरहेड लगाते हैं।

माध्यमिक कुंजी

नोट करने के लिए अंक -

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

  • किसी भी क्षेत्र को द्वितीयक कुंजी के रूप में उपयोग किया जा सकता है। यह खंड अनुक्रम क्षेत्र नहीं होना चाहिए।

  • इंडेक्स सोर्स सेगमेंट के भीतर सिंगल कीज़ का कोई भी संयोजन हो सकता है।

  • माध्यमिक कुंजी मानों को विशिष्ट नहीं होना चाहिए।

माध्यमिक डेटा संरचनाएँ

नोट करने के लिए अंक -

  • जब हम एक द्वितीयक सूचकांक बनाते हैं, तो डेटाबेस की स्पष्ट पदानुक्रमित संरचना भी बदल जाती है।

  • सूचकांक लक्ष्य खंड स्पष्ट मूल खंड बन जाता है। जैसा कि निम्नलिखित छवि में दिखाया गया है, इंजीनियरिंग खंड रूट सेगमेंट बन जाता है, भले ही वह रूट सेगमेंट न हो।

  • सेकेंडरी इंडेक्स के कारण होने वाले डेटाबेस स्ट्रक्चर की रीस्ट्रक्चरिंग को सेकेंडरी डेटा स्ट्रक्चर के रूप में जाना जाता है।

  • माध्यमिक डेटा संरचनाएं डिस्क पर मौजूद मुख्य भौतिक डेटाबेस संरचना में कोई बदलाव नहीं करती हैं। यह एप्लिकेशन प्रोग्राम के सामने डेटाबेस संरचना को बदलने का एक तरीका है।

स्वतंत्र और संचालक

नोट करने के लिए अंक -

  • जब कोई AND (* या &) ऑपरेटर सेकंडरी इंडेक्स के साथ उपयोग किया जाता है, तो उसे एक निर्भर और ऑपरेटर के रूप में जाना जाता है।

  • एक स्वतंत्र और (#) हमें योग्यता निर्दिष्ट करने की अनुमति देता है जो एक आश्रित और के साथ असंभव होगा।

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

  • हम एक एसएसए को एक स्वतंत्र के साथ कोड कर सकते हैं और यह निर्दिष्ट करने के लिए कि लक्ष्य खंड की एक घटना को दो या अधिक निर्भर क्षेत्रों में फ़ील्ड के आधार पर संसाधित किया जा सकता है।

01 ITEM-SELECTION-SSA.
   05 FILLER           PIC X(8).
   05 FILLER           PIC X(1) VALUE '('.
   05 FILLER           PIC X(10).
   05 SSA-KEY-1        PIC X(8).
   05 FILLER           PIC X   VALUE '#'.
   05 FILLER           PIC X(10).
   05 SSA-KEY-2        PIC X(8).
   05 FILLER           PIC X   VALUE ')'.

विरल सीक्वेंसिंग

नोट करने के लिए अंक -

  • स्पार्स अनुक्रमण को स्पार्स अनुक्रमण के रूप में भी जाना जाता है। हम कुछ इंडेक्स सोर्स सेगमेंट को सेकेंडरी इंडेक्स डेटाबेस के साथ स्पार्स सीक्वेंसिंग का उपयोग करके इंडेक्स से हटा सकते हैं।

  • प्रदर्शन में सुधार के लिए स्पार्स अनुक्रमण का उपयोग किया जाता है। जब सूचकांक स्रोत खंड की कुछ घटनाओं का उपयोग नहीं किया जाता है, तो हम इसे हटा सकते हैं।

  • डीएल / मैं एक दमन मूल्य या एक दमन दिनचर्या या दोनों का उपयोग करता है यह निर्धारित करने के लिए कि क्या एक खंड को अनुक्रमित किया जाना चाहिए।

  • यदि इंडेक्स सोर्स सेगमेंट में अनुक्रम फ़ील्ड का मान दमन मूल्य से मेल खाता है, तो कोई इंडेक्स संबंध स्थापित नहीं होता है।

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

  • जब स्पार्स इंडेक्सिंग का उपयोग किया जाता है, तो इसके कार्यों को DL / I द्वारा नियंत्रित किया जाता है। हमें आवेदन कार्यक्रम में इसके लिए विशेष प्रावधान करने की आवश्यकता नहीं है।

DBDGEN आवश्यकताएँ

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

PSBGEN आवश्यकताएँ

एक डेटाबेस के लिए द्वितीयक सूचकांक बनाने के बाद, डीबीए को पीएसबी बनाने की आवश्यकता है। कार्यक्रम के लिए PSBGEN PSB मैक्रो के PROCSEQ पैरामीटर पर डेटाबेस के लिए उचित प्रसंस्करण अनुक्रम को निर्दिष्ट करता है। PROCSEQ पैरामीटर के लिए, DBA माध्यमिक इंडेक्स डेटाबेस के लिए DBD नाम को कोड करता है।

IMS डेटाबेस में एक नियम है कि प्रत्येक सेगमेंट के प्रकार में केवल एक माता-पिता हो सकते हैं। यह भौतिक डेटाबेस की जटिलता को सीमित करता है। कई DL / I अनुप्रयोगों को एक जटिल संरचना की आवश्यकता होती है जो एक खंड को दो मूल खंड प्रकार रखने की अनुमति देता है। इस सीमा को पार करने के लिए, डीएल / I डीबीए को तार्किक संबंधों को लागू करने की अनुमति देता है जिसमें एक खंड में शारीरिक और तार्किक दोनों माता-पिता हो सकते हैं। हम एक भौतिक डेटाबेस में अतिरिक्त संबंध बना सकते हैं। तार्किक संबंध को लागू करने के बाद नई डेटा संरचना को लॉजिकल डेटाबेस के रूप में जाना जाता है।

तार्किक संबंध

एक तार्किक संबंध में निम्नलिखित गुण होते हैं -

  • एक तार्किक संबंध दो खंडों के बीच का एक मार्ग है जो तार्किक रूप से संबंधित है और शारीरिक रूप से नहीं।

  • आमतौर पर एक तार्किक संबंध अलग-अलग डेटाबेस के बीच स्थापित होता है। लेकिन एक विशेष डेटाबेस के खंडों के बीच संबंध रखना संभव है।

निम्न छवि दो अलग-अलग डेटाबेस दिखाती है। एक छात्र डेटाबेस है, और दूसरा एक लाइब्रेरी डेटाबेस है। हम छात्र डेटाबेस से पुस्तकें जारी सेगमेंट और लाइब्रेरी डेटाबेस से पुस्तकें खंड के बीच एक तार्किक संबंध बनाते हैं।

जब आप तार्किक संबंध बनाते हैं तो यह लॉजिकल डेटाबेस दिखता है -

तार्किक बाल खंड

तार्किक बाल खंड एक तार्किक संबंध का आधार है। यह एक भौतिक डेटा सेगमेंट है, लेकिन DL / I के लिए, यह ऐसा प्रतीत होता है जैसे इसके दो माता-पिता हैं। उपरोक्त उदाहरण में पुस्तकें खंड में दो मूल खंड हैं। जारी की गई पुस्तकों का खंड तार्किक माता-पिता है और पुस्तकालय खंड भौतिक माता-पिता है। एक तार्किक चाइल्ड सेगमेंट की घटना में केवल एक लॉजिकल पैरेंट सेगमेंट की घटना होती है और एक लॉजिकल सेगमेंट में होने वाली कई लॉजिकल सेगमेंट की घटनाएँ होती हैं।

तार्किक जुड़वाँ बच्चे

लॉजिकल ट्विन्स एक तार्किक चाइल्ड सेगमेंट प्रकार की घटनाएँ होती हैं, जो लॉजिकल पैरेंट सेगमेंट प्रकार की एकल घटना के अधीन होती हैं। DL / I तार्किक चाइल्ड सेगमेंट को वास्तविक भौतिक चाइल्ड सेगमेंट के समान बनाता है। इसे वर्चुअल लॉजिकल चाइल्ड सेगमेंट के रूप में भी जाना जाता है।

तार्किक संबंधों के प्रकार

एक डीबीए सेगमेंट के बीच तार्किक संबंध बनाता है। एक तार्किक संबंध को लागू करने के लिए, डीबीए को शामिल किए गए भौतिक डेटाबेस के लिए DBDGENs में निर्दिष्ट करना होगा। तार्किक संबंध तीन प्रकार के होते हैं -

  • Unidirectional
  • द्विदिश आभासी
  • द्विदिश शारीरिक

दिशाहीन

तार्किक कनेक्शन तार्किक बच्चे से तार्किक माता-पिता तक जाता है और यह दूसरे तरीके से नहीं जा सकता है।

द्विदिश आभासी

यह दोनों दिशाओं में पहुंच की अनुमति देता है। इसकी शारीरिक संरचना में तार्किक बच्चे और संबंधित आभासी तार्किक बच्चे को युग्मित खंडों के रूप में देखा जा सकता है।

द्विदिश शारीरिक

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

प्रोग्रामिंग विचार

तार्किक डेटाबेस का उपयोग करने के लिए प्रोग्रामिंग विचार इस प्रकार हैं -

  • DL / I कॉल डेटाबेस तक पहुँचने के लिए तार्किक डेटाबेस के साथ भी रहता है।

  • कार्यक्रम विनिर्देश ब्लॉक उस संरचना को इंगित करता है जिसका उपयोग हम अपने कॉल में करते हैं। कुछ मामलों में, हम पहचान नहीं सकते कि हम एक तार्किक डेटाबेस का उपयोग कर रहे हैं।

  • तार्किक संबंध डेटाबेस प्रोग्रामिंग में एक नया आयाम जोड़ते हैं।

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

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

संबंधित खंड

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

  • तार्किक बाल खंड
  • गंतव्य मूल खंड

तार्किक बाल खंड में निम्नलिखित दो भाग होते हैं -

  • गंतव्य माता-पिता संबंधित कुंजी (DPCK)
  • तार्किक बाल उपयोगकर्ता डेटा

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

डेटाबेस व्यवस्थापक को सिस्टम विफलताओं के मामले में डेटाबेस पुनर्प्राप्ति के लिए योजना बनाने की आवश्यकता होती है। विफलताएं कई प्रकार की हो सकती हैं जैसे कि एप्लिकेशन क्रैश, हार्डवेयर त्रुटियां, पावर विफलताएं आदि।

सरल दृष्टिकोण

डेटाबेस रिकवरी के कुछ सरल तरीके इस प्रकार हैं -

  • महत्वपूर्ण डेटासेट की समय-समय पर बैकअप प्रतियां बनाएं ताकि डेटासेट के विरुद्ध पोस्ट किए गए सभी लेनदेन बरकरार रहें।

  • यदि सिस्टम विफलता के कारण कोई डेटासेट खराब हो जाता है, तो बैकअप कॉपी को पुनर्स्थापित करके उस समस्या को ठीक किया जाता है। फिर संचित लेन-देन को बैकअप प्रति में पोस्ट किया जाता है ताकि उन्हें अद्यतित किया जा सके।

सरल दृष्टिकोण के नुकसान

डेटाबेस रिकवरी के लिए सरल दृष्टिकोण के नुकसान इस प्रकार हैं -

  • संचित लेनदेन को पुनः पोस्ट करने में बहुत समय लगता है।

  • वसूली समाप्त होने तक सभी अन्य अनुप्रयोगों को निष्पादन के लिए इंतजार करना होगा।

  • डेटाबेस रिकवरी फ़ाइल रिकवरी की तुलना में लंबा है, अगर तार्किक और माध्यमिक सूचकांक संबंध शामिल हैं।

असामान्य समाप्ति दिनचर्या

एक DL / I प्रोग्राम उस तरह से क्रैश होता है जो मानक प्रोग्राम क्रैश होने के तरीके से अलग होता है क्योंकि एक मानक प्रोग्राम सीधे ऑपरेटिंग सिस्टम द्वारा निष्पादित होता है, जबकि DL / I प्रोग्राम नहीं है। एक असामान्य समाप्ति दिनचर्या को नियोजित करके, सिस्टम हस्तक्षेप करता है ताकि पुनर्प्राप्ति ABnormal END (ABEND) के बाद की जा सके। असामान्य समाप्ति दिनचर्या निम्नलिखित क्रियाएं करती है -

  • सभी डेटासेट बंद करता है
  • कतार में सभी लंबित नौकरियों को रद्द करें
  • ABEND का मूल कारण जानने के लिए एक संग्रहण डंप बनाता है

इस दिनचर्या की सीमा यह है कि यह सुनिश्चित नहीं करता है कि उपयोग में डेटा सही है या नहीं।

डीएल / आई लॉग

जब कोई एप्लिकेशन प्रोग्राम ABENDs करता है, तो एप्लिकेशन प्रोग्राम द्वारा किए गए परिवर्तनों को वापस करना, त्रुटि को ठीक करना और एप्लिकेशन प्रोग्राम को फिर से चलाना आवश्यक है। ऐसा करने के लिए, डीएल / आई लॉग होना आवश्यक है। यहाँ DL / I लॉगिंग के बारे में मुख्य बातें दी गई हैं -

  • एक DL / I एक फ़ाइल में एक एप्लिकेशन प्रोग्राम द्वारा किए गए सभी परिवर्तनों को रिकॉर्ड करता है जिसे लॉग फ़ाइल के रूप में जाना जाता है।

  • जब एप्लिकेशन प्रोग्राम एक खंड को बदलता है, तो छवि से पहले और बाद में चित्र DL / I द्वारा बनाए जाते हैं।

  • यदि एप्लिकेशन प्रोग्राम क्रैश हो जाता है, तो खंडों को पुनर्स्थापित करने के लिए इन खंड छवियों का उपयोग किया जा सकता है।

  • DL / I डेटाबेस परिवर्तन को रिकॉर्ड करने के लिए राइट-फॉरवर्ड लॉगिंग नामक तकनीक का उपयोग करता है। राइट-फॉरवर्ड लॉगिंग के साथ, डेटाबेस परिवर्तन वास्तविक डेटासेट को लिखे जाने से पहले लॉग डेटासेट को लिखा जाता है।

  • चूंकि लॉग हमेशा डेटाबेस से आगे होता है, रिकवरी यूटिलिटी किसी भी डेटाबेस परिवर्तन की स्थिति निर्धारित कर सकती है।

  • जब प्रोग्राम एक डेटाबेस सेगमेंट को बदलने के लिए कॉल निष्पादित करता है, तो DL / I इसके लॉगिंग भाग का ध्यान रखता है।

वसूली - आगे और पीछे

डेटाबेस रिकवरी के दो दृष्टिकोण हैं -

  • Forward Recovery - DL / I परिवर्तन डेटा को संग्रहीत करने के लिए लॉग फ़ाइल का उपयोग करता है। इस लॉग फ़ाइल का उपयोग करके संचित लेनदेन को फिर से पोस्ट किया जाता है।

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

जांच की चौकी

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

  • सबसे हाल ही में चेकपॉइंट से पहले किए गए डेटाबेस परिवर्तन पिछड़े वसूली से उलट नहीं हैं।

  • सबसे हाल ही में चेकपॉइंट के बाद डेटाबेस परिवर्तन लॉग किए गए हैं जो फ़ॉरवर्ड रिकवरी के दौरान डेटाबेस की इमेज कॉपी पर लागू नहीं होते हैं।

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

  • बैच कार्यक्रमों के लिए डिफ़ॉल्ट यह है कि चेकपॉइंट प्रोग्राम की शुरुआत है।

  • एक चेकपॉइंट कॉल (CHKP) का उपयोग करके एक चेकपॉइंट स्थापित किया जा सकता है।

  • एक चेकपॉइंट कॉल के कारण DL / I लॉग पर एक चेकपॉइंट रिकॉर्ड लिखा जाता है।

नीचे दिखाया गया CHKP कॉल का सिंटैक्स है -

CALL 'CBLTDLI' USING DLI-CHKP
                     PCB-NAME
                     CHECKPOINT-ID

दो चौकी के तरीके हैं -

  • Basic Checkpointing - यह प्रोग्रामर को चेकपॉइंट कॉल जारी करने की अनुमति देता है कि रिकवरी प्रोसेसिंग के दौरान DL / I रिकवरी उपयोगिताओं का उपयोग करता है।

  • Symbolic Checkpointing- यह चेकपॉइंटिंग का एक उन्नत रूप है जो विस्तारित पुनरारंभ सुविधा के साथ संयोजन में उपयोग किया जाता है। प्रतीकात्मक चेकपॉइंटिंग और विस्तारित पुनरारंभ एक साथ होते हैं, एप्लिकेशन प्रोग्रामर को प्रोग्राम्स को कोड करने देता है ताकि वे चेकपॉइंट के बाद बिंदु पर प्रसंस्करण फिर से शुरू कर सकें।