Google
オフコン練習帳内を検索
インターネット全体を検索

NECオフコン関連
オフコン一般
情報
トップ  >  ファイル編成とアクセスモード、処理モード

ファイル編成とアクセスモード、処理モード

1 ファイル編成とは

WindowsやLinuxはプログラミングするときは「ファイルの構造はいちから自分で考えてください」という感じです。ランダムアクセスする場合はそのプログラムとファイル構造を自分で考えなければならないし、ファイルをキーで検索するような構造にしようとしたら結構大変なことになります。

オフコンは事務処理向けのコンピュータです。事務処理に使われるようなファイルの構造というのはある程度決まってきます。そこでオフコンのOSであるA−VXでは、事務処理でよく使われるファイルの構造をあらかじめいくつか用意しています。プログラミングするときはその用意されたファイルの中から選ぶことによって、ファイルの構造の設計を効率化できます。またそのファイルの構造に対応した命令が言語(COBOL言語など)に用意されている為、プログラムも容易となります。

あらかじめ用意された構造というのは、順番にファイルを読み書きするタイプのもの、ファイルの任意の位置のレコードをいきなり読み書きできるタイプ、キーに対応するレコードを読み書きできるタイプなどがあります。

このあらかじめ用意されたファイルの種類のことをファイル編成といいます。

2 ファイル編成の種類

A−VXにはいくつかの種類のファイル編成があります。

  • 順編成ファイル
  • 相対編成ファイル
  • 索引順編成ファイル
  • 複数索引順編成ファイル
  • 待機区分編成ファイル
  • 待機結合編成ファイル

A−VXでファイルを使うときは、この中からファイル編成を選び、それをカスタマイズして使用することになります。

注意点としては、A−VXと世間で一般的に言われている○○編成ファイルでは、同じ名前でも構造が異なっているものがあります。メインフレーム系のOSにも○○編成というファイル編成があります。順編成のような単純のものはほぼ同じですが、たとえば索引(順)編成ファイルは、メインフレーム系のものと比べてかなり簡単な構造になっています。

2.1 順編成ファイル

Windowsのテキストファイルのような形式のファイルです。テキストファイルは1行に何文字(何バイト)も書けますが、A−VXの順編成ファイルは1行に書ける文字数(バイト数)が決まっています。(1行=1レコード)

ファイルを読み込んだり、書き込んだりする時は、先頭のレコードから順番に行います。つまり、順編成ファイルは順アクセスしかできず、乱アクセスや動的アクセスはできないということです。

順編成ファイルについては、別にもう少し詳しく説明します。

2.2 相対編成ファイル

順編成ファイルに、相対レコード番号というキーが追加されたような感じのファイルです。

1レコードが固定長であったり、ブロック化できるという部分は順編成ファイルと全く同じです。

順編成ファイルのようにファイルの順番に読み込んだり書き込んだりもできるし、相対レコード番号を利用して、ファイルの途中のレコードから読み書きすることもできます。つまり、相対編成ファイルは、順アクセス、乱アクセス、動的アクセス可能ということです。

相対編成ファイルについては、別にもう少し詳しく説明します。

2.3 索引順編成ファイル

索引部とデータ部で構成されているファイルです。データ部中に1つだけ索引キーがあり、そのキーを使ってファイルの途中のレコードから読み書きすることができます。もちろんファイルの先頭から読み書きすることも可能です。索引順編成ファイルは、順アクセス、乱アクセス、動的アクセス可能ということです。

索引順編成ファイルについて、別にもう少し詳しく説明します。

2.4 複数索引順編成ファイル

索引順編成ファイルのデータ部の索引キーと索引部が複数ある編成ファイルです。磁気ディスク上に作成できます。キーが複数あるため、データの追加・削除を行った場合、キーの再編成を行う必要があります。あとはだいたい索引順編成ファイルと同じ。

複雑な構造のファイルのため、いろいろと注意事項があります。「データ管理説明書」の「複数索引順編成ファイル」の「プログラミング上の注意事項」を読みましょう。

複数索引順編成ファイルについて、別にもう少し詳しく説明します。

2.5 待機区分編成ファイル

これは、一般的にはCOBOLプログラム上やユーザプログラムから読んだり書いたりできない、A−VXのシステム専用のファイルです。LMライブラリファイル(LML)などのようなライブラリファイルが待機区分編成ファイルです。

使用目的が限られており、データファイルとして使用できません。

待機区分編成ファイルについて、別にもう少し詳しく説明します。

2.6 待機結合編成ファイル

これも、一般的にはCOBOLプログラム上やユーザプログラムから読んだり書いたりできない、A−VXのシステム専用のファイルです。SUライブラリファイル(SUL)やCUライブラリファイル(CUL)、ジョブストリームファイル(JS)などのライブラリファイルが待機結合編成ファイルです。

使用目的が限られており、データファイルとして使用できません。

待機結合編成ファイルについて、別にもう少し詳しく説明します。

3 アクセスモード

まずNECの説明書を引用します。

アクセスモード(呼び出し方法)とはファイルに対してレコードをどのような方法で書き出し、それをどのような方法で読み取るかを示すものである。
データ管理では、次の三つのアクセスモードが用意されている。
・順アクセス(順呼び出し)
・乱アクセス(乱呼び出し)
・動的アクセス(動的呼び出し)
ファイルはオープンされてからクローズされるまで、いずれか一つのアクセスモード下で処理される。

[データ管理説明書(2009年11月版)−4.3 アクセスモード]より

これに関しては私の方で追加する情報はあまりありません。

3.1 順アクセス

ファイルに格納されている順番にレコードを読み書きできるモードです。

全てのファイル編成で順アクセスができます。

順編成ファイル、相対編成ファイルの場合は、ファイルの先頭から順番にレコードをアクセスします。索引順編成ファイル、複数索引順編成ファイルの場合は、キー値の昇順(小→大)にレコードをアクセスします。

3.2 乱アクセス

キーや相対レコード番号で指定してレコードを読み書きできるモードです。

順編成以外のファイルで使用できます。

相対編成ファイルの場合は、プログラムで指定された相対レコード番号をもとに、該当レコードをアクセスします。索引順編成ファイル、複数索引順編成ファイルの場合は、プログラムで指定されたキー値をもとに、該当レコードをアクセスします。

3.3 動的アクセス

レコードを順番に読み書きすることもできるし、キーや相対レコード番号で指定して読み書きすることもできるモードです。

順編成以外のファイルで使用できます。

例えばある値でソート済みのファイルに対して、「最初はキーを使ってレコードを読んで、それ以降はレコードを順番に読んでいく」のような使い方をしたりします。

相対編成ファイルの場合は、プログラムで指定された相対レコード番号のレコードをアクセスした後、その相対レコード番号の位置から順番に次のレコードをアクセスします。索引順編成ファイルの場合は、プログラムで指定されたキー値のレコードをアクセスした後、その位置から索引部の順番にレコードをアクセスします。複数索引順編成ファイルの場合は、プログラムで指定された索引ファイルのキー値をもとにレコードをアクセスした後、その位置から索引ファイルの順番にレコードをアクセスします。

下の表はアクセスモードとファイル編成の関係を整理したものです。

アクセスモード順編成相対編成索引順編成複数索引順編成
順アクセス
乱アクセス×
動的アクセス×

4 処理モード

これもまずNECの説明書を引用します。

処理モード(オープンモード)とは、ファイルに対する処理の仕方を定めるもので、次の4種がある。
・入力処理モード
・出力処理モード
・更新(入出力両用)処理モード
・追加(拡張)処理モード
処理モードは、ファイルのオープン時に指定され、ファイルがクローズされるまで変更されない。

[データ管理説明書(2009年11月版)−4.4 処理モード]より

COBOLプログラムだと、OPEN命令に指定します。NECの説明書には追加処理モードが許されていないとか存在するとか書いてありますが、少なくともCOBOLプログラムでは使えます。

下の表は処理モードとファイル編成の関係を整理したものです。

入力処理順編成相対編成索引順編成複数索引順編成
出力処理
更新処理
追加処理×××

5 他にファイル編成ってあるの?

A−VXで使えるファイル編成は、今まで説明したもので全部です。

ちなみに富士通のオフコンには直接データ編成ファイルなるものがありますが、これと同等のファイル形式はA−VXにありません。同じことを実現しようとしたら、たぶんA−VX/RDBを使用することになるでしょう。

メインフレーム系には乱編成ファイルと呼ばれるものがあったりするようですが、それもA−VXにはありません。もちろんA−VXでも相対編成ファイルなどを組み合わせて乱編成ファイルを作ることは可能だと思われます。

6 キー・二重キー

索引順編成ファイル、複数索引順編成ファイルには、キーというものがあり、キーを使ってレコードを選択してアクセスすることができます。

キーは索引部というところに入っています。索引順編成ファイルには索引順編成ファイル内に索引部があり、複数索引順編成ファイルには索引部はキーファイルというところに存在しています。

索引部は、レコードのキーの部分とそのキーに対応するレコードの格納位置が、キー値の昇順(小→大)に格納されています。(データ部は、レコードがファイルに書き込まれた順番に格納されている。)

索引順編成ファイル、複数索引順編成ファイルのデータのアクセスは、索引部を経由して行われるので、キー値によるアクセスが可能となります。

二重キーとは、索引順編成ファイルや複数索引順編成ファイルの索引を持つファイルで同じキー値を持つレコードが発生することです。

二重キーが許されているキーのことを「二重キーあり」のキーと言います。

例えば、索引順編成ファイルの取引先マスタで、郵便番号がキー項目のファイルを考えてみます。当然、同じ郵便番号の取引先が登録される可能性があります。その場合は、郵便番号のキー項目は「二重キーあり」の指定をしなければなりません。

二重キーありの指定を行うと、索引順編成ファイルの場合、同じキー値の索引が複数作成されるわけではなく、後から入ってきた二重キーのレコードの番地(アドレス)が先に入っていたレコードの後ろに書き込まれることになります。

最大8個
キーファイルの同時更新モードにすれば、再編成する必要はない。がアクセスが遅くなるので、いろいろ工夫する必要がある。
LMLにメンバを登録する時にファイルオーバフローしそうになると自動的に「ファイルの再編成処理」を行うがSULやJSがオーバフローしそうになっても再編成処理をしない。これは、LMLが待機区分編成ファイルで、SULやJSが待機結合編成ファイルだから。待機区分編成ファイルは必ず連続領域に書き込まなければならないので、メンバの登録削除を繰り返すと断片化が発生する。だからオーバフローしそうになったら、断片化を解消するために再編成処理が行われる。一方、待機結合編成ファイルはメンバを登録する時に連続領域でなくても良いので、断片化は生じない。