COBOL - फ़ाइल संगठन

फ़ाइल संगठन इंगित करता है कि किसी फ़ाइल में रिकॉर्ड कैसे व्यवस्थित किए जाते हैं। फ़ाइलों के लिए विभिन्न प्रकार के संगठन हैं ताकि रिकॉर्ड तक पहुंचने की उनकी दक्षता में वृद्धि हो सके। निम्नलिखित फ़ाइल संगठन योजनाएं हैं -

  • अनुक्रमिक फ़ाइल संगठन
  • अनुक्रमित अनुक्रमिक फ़ाइल संगठन
  • रिश्तेदार फ़ाइल संगठन

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

अनुक्रमिक फ़ाइल संगठन

एक अनुक्रमिक फ़ाइल में ऐसे रिकॉर्ड होते हैं जो अनुक्रमिक क्रम में संग्रहीत और एक्सेस किए जाते हैं। अनुक्रमिक फ़ाइल संगठन की प्रमुख विशेषताएं निम्नलिखित हैं -

  • रिकॉर्ड्स को क्रमानुसार पढ़ा जा सकता है। 10 वें रिकॉर्ड को पढ़ने के लिए , पिछले 9 रिकॉर्डों को पढ़ना चाहिए।

  • रिकॉर्ड क्रमबद्ध क्रम में लिखे गए हैं। एक नया रिकॉर्ड बीच में नहीं डाला जा सकता है। फ़ाइल के अंत में एक नया रिकॉर्ड हमेशा डाला जाता है।

  • अनुक्रमिक फ़ाइल में रिकॉर्ड रखने के बाद, रिकॉर्ड को हटाना, छोटा या लंबा करना संभव नहीं है।

  • एक बार डाले जाने के बाद, अभिलेखों का क्रम कभी नहीं बदला जा सकता

  • रिकॉर्ड का अद्यतन संभव है। एक रिकॉर्ड को अधिलेखित किया जा सकता है, अगर नया रिकॉर्ड लंबाई पुराने रिकॉर्ड लंबाई के समान है।

  • मुद्रण के लिए अनुक्रमिक आउटपुट फ़ाइलें अच्छा विकल्प हैं।

वाक्य - विन्यास

निम्नलिखित अनुक्रमिक फ़ाइल संगठन का सिंटैक्स है -

INPUT-OUTPUT SECTION.
FILE-CONTROL.
   SELECT file-name ASSIGN TO dd-name-jcl
   ORGANIZATION IS SEQUENTIAL

अनुक्रमित अनुक्रमिक फ़ाइल संगठन

अनुक्रमित अनुक्रमिक फ़ाइल में ऐसे रिकॉर्ड होते हैं जिन्हें क्रमिक रूप से एक्सेस किया जा सकता है। सीधी पहुंच भी संभव है। इसमें दो भाग होते हैं -

  • Data File अनुक्रमिक योजना में रिकॉर्ड शामिल हैं।

  • Index File डेटा फ़ाइल में प्राथमिक कुंजी और उसका पता होता है।

अनुक्रमिक फ़ाइल संगठन की प्रमुख विशेषताएं निम्नलिखित हैं -

  • रिकॉर्ड्स को अनुक्रमिक फ़ाइल संगठन की तरह ही अनुक्रमिक क्रम में पढ़ा जा सकता है।

  • यदि प्राथमिक कुंजी ज्ञात हो तो रिकॉर्ड्स को बेतरतीब ढंग से एक्सेस किया जा सकता है। इंडेक्स फ़ाइल का उपयोग रिकॉर्ड का पता प्राप्त करने के लिए किया जाता है और फिर डेटा फ़ाइल से रिकॉर्ड प्राप्त किया जाता है।

  • इस फ़ाइल सिस्टम में सॉर्ट किए गए इंडेक्स को बनाए रखा जाता है जो फ़ाइल में रिकॉर्ड की स्थिति के लिए महत्वपूर्ण मूल्य से संबंधित है।

  • रिकॉर्ड लाने के लिए वैकल्पिक सूचकांक भी बनाया जा सकता है।

वाक्य - विन्यास

अनुक्रमित अनुक्रमिक फ़ाइल संगठन का सिंटैक्स निम्नलिखित है -

INPUT-OUTPUT SECTION.
FILE-CONTROL.
   SELECT file-name ASSIGN TO dd-name-jcl
   ORGANIZATION IS INDEXED
   RECORD KEY IS primary-key
   ALTERNATE RECORD KEY IS rec-key

रिश्तेदार फ़ाइल संगठन

एक रिश्तेदार फ़ाइल में उनके द्वारा आदेशित रिकॉर्ड होते हैं relative address। रिश्तेदार फ़ाइल संगठन की प्रमुख विशेषताएं निम्नलिखित हैं -

  • रिकॉर्ड्स को अनुक्रमिक और अनुक्रमित फ़ाइल संगठन की तरह ही अनुक्रमिक क्रम में पढ़ा जा सकता है।

  • रिश्तेदार कुंजी का उपयोग करके रिकॉर्ड तक पहुँचा जा सकता है। सापेक्ष कुंजी फ़ाइल के प्रारंभ के पते के सापेक्ष रिकॉर्ड के स्थान का प्रतिनिधित्व करती है।

  • रिश्तेदार कुंजी का उपयोग करके रिकॉर्ड डाला जा सकता है। सापेक्ष कुंजी का उपयोग करके सापेक्ष पते की गणना की जाती है।

  • रिलेटिव फ़ाइल रिकॉर्ड्स के लिए सबसे तेज़ पहुँच प्रदान करती है।

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

वाक्य - विन्यास

निम्नलिखित रिश्तेदार फ़ाइल संगठन का सिंटैक्स है -

INPUT-OUTPUT SECTION.
FILE-CONTROL.
   SELECT file-name ASSIGN TO dd-name-jcl
   ORGANIZATION IS RELATIVE
   RELATIVE KEY IS rec-key