ソートマージ
パラメタには,必ず指定するパラメタと任意に指定できるパラメタの2種類があります。
wnsortexコマンドのパラメタファイルの先頭を意味します。この指定は省略できません。
wnsortexコマンドで実行する機能を「exec_opt=」+オペランドの形式で指定します。実行オプションの指定形式を次の図に,オペランドを次の表に示します。
図11-3 実行オプションの指定形式(拡張SORTコマンド)
表11-2 実行オプションのオペランド(拡張SORTコマンド)
オペランド | 意味 |
---|---|
select | レコードを選択する。 |
sort | レコードをソートする。 |
sum | レコードを集約する。 |
オペランドを複数指定した場合は,選択,ソート,集約の順に実行します。例えば,ソートと選択を指定した場合は,選択されたデータをソートします。
wnsortexコマンドで実行する機能オプションを「sort_opt=」+オペランドの形式で指定します。機能オプションのオペランドを次の表に示します。
表11-3 機能オプションのオペランド(拡張SORTコマンド)
オペランド | 内容 |
---|---|
d | ファイル中に重複したキーのレコードがある場合,それらのデータを入力順に並べることを指定する(重複レコードの入力順序保存機能)。 |
i | 出力ファイルと同じ名前のファイルがすでにある場合,そのファイルの内容が書き換えられるのを防ぐ(既存ファイルの書き換え防止)。 |
v | EBCDIKコードの体系に従ってキーを比較する。 |
b※1 | キーが数値項目の場合,big endian※2の数値として扱う。 |
u | 選択条件を満足しないレコードだけを入力する。 |
h | 集約項目の属性に2進数を指定した場合,10進数の桁数でオーバーフローの判定をする。 |
複数のオペランドを指定する場合は,「di」のようにつなげて指定します。「d△i」のように分けて指定した場合は,最初に指定したオペランドが有効になります。
また,この指定は省略できます。省略した場合は,次のようになります。
なお,機能オプションを指定する場合は,次の点に注意してください。
入力ファイルのファイル編成を「file_org=」+オペランドの形式で指定します。複数の入力ファイルを指定する場合は,すべて同じファイル編成にしてください。また,この指定は省略できません。入力ファイルのファイル編成のオペランドを次の表に示します。
表11-4 入力ファイルのファイル編成のオペランド(拡張SORTコマンド)
オペランド | 内容 |
---|---|
s | 固定長順編成ファイルを指定する。 |
v | 可変長順編成ファイルを指定する。 |
r | 固定長相対ファイルを指定する。 |
w | 可変長相対ファイルを指定する。 |
i | 固定長索引ファイルを指定する。 |
x | 可変長索引ファイルを指定する。 |
a | テキストファイルを指定する。 |
出力ファイルのファイル編成のオペランドを,コロン(:)で区切って指定します。出力ファイルのファイルの形式(固定長,可変長またはテキスト)は,入力ファイルと同じにしてください。
入力ファイルが順ファイル,相対ファイルまたはテキストファイルの場合,この指定は省略できます。指定を省略した場合は,入力ファイルと同じファイル編成が設定されます。入力ファイルが索引ファイルの場合は,順ファイルまたは相対ファイルのどちらかを必ず指定してください。
なお,指定を省略するときは,コロンも省略します。省略時にコロンを指定した場合はエラーとなります。
出力ファイルのファイル編成のオペランドを次の表に示します。
表11-5 出力ファイルのファイル編成のオペランド(拡張SORTコマンド)
オペランド | 内容 |
---|---|
s | 固定長順編成ファイルを指定する。 |
v | 可変長順編成ファイルを指定する。 |
r | 固定長相対ファイルを指定する。 |
w | 可変長相対ファイルを指定する。 |
a | テキストファイルを指定する。 |
入力ファイルのファイル編成ごとのレコード長の指定方法を次の表に示します。
表11-6 入力ファイルのファイル編成ごとのレコード長の指定方法(拡張SORTコマンド)
入力ファイル編成 | レコード長の指定方法 |
---|---|
固定長順編成ファイル | ファイルのレコード長を「1〜65,535」バイトの範囲で指定します。 |
可変長順編成ファイル | 指定は不要です。指定しても無視されます。 ただし,入力できるレコード長の範囲は,1〜65,535バイトです。 |
固定長相対ファイル | |
可変長相対ファイル | |
固定長索引ファイル | 指定は不要です。指定しても無視されます。 ただし,入力できるレコード長の範囲は,1〜65,503バイトです。 |
可変長索引ファイル | |
テキストファイル | ファイルの最大レコード長を「1〜65,535」バイトの範囲で指定します。レコード長には,改行文字「X'0A'」は含みません。 省略できます。省略した場合「65,535」バイトが設定されます。 レコード長を指定した方がソート時間が短くなります。 |
ソート用一時ファイルを割り当てるディレクトリを指定します。この指定は,実行オプションで「sort」を指定した場合だけ有効となります。
ソート用一時ファイルを使用する条件については,「16. 一時ファイルの作成条件とファイル容量の算出方法」を参照してください。
また,この指定は省略できます。指定を省略した場合,使用するディレクトリの優先順位は,次の順となります。
表11-7 一時ファイルが割り当てられるディレクトリ(拡張SORTコマンド)
OS | ディレクトリ |
---|---|
Windows | 次の優先順位で使用するディレクトリが決まります。
|
環境ファイルの設定方法については,「15. 環境ファイルの設定」を参照してください。
中間ファイルを割り当てるディレクトリを指定します。この指定は,実行オプションを2個以上指定したときだけ有効となります。
また,この指定は省略できます。指定を省略した場合,使用するディレクトリの優先順位は,次の順となります。
マージ用一時ファイルを割り当てるディレクトリを指定します。この指定は,実行オプションで「sort」を指定し,ソート実行時にマージ用一時ファイルを使用する場合だけ有効となります。
マージ用一時ファイルを使用する条件については「16. 一時ファイルの作成条件とファイル容量の算出方法」を参照してください。
また,この指定は省略できます。指定を省略した場合,使用するディレクトリの優先順位は,次の順となります。
レコードを選択するための選択条件式を指定します。この指定は,実行オプションで「select」を指定した場合だけ有効となります。また,この指定は省略できません。指定できる条件式の個数は1〜128個です。
選択条件式の形式を次の図に示します。
図11-4 選択条件式の形式(拡張SORTコマンド)
なお,スペースを入れてよいのは,論理演算子の前後と比較演算子の前後だけです。
比較項目の属性を指定します。比較項目の属性のオペランドを次の表に示します。
表11-8 比較項目の属性のオペランド(拡張SORTコマンド)
オペランド | 内容 |
---|---|
j | 比較項目が文字(JIS8単位コード※)であることを指定する。 |
c | 比較項目が文字であることを指定する。 |
n | 比較項目が符号付き固定小数点2進数であることを指定する。 |
m | 比較項目が符号なし2進数であることを指定する。 |
p | 比較項目が内部10進数であることを指定する。 |
z | 比較項目が外部10進数であることを指定する。 |
x | 比較項目が左符号付き外部10進数であることを指定する。 |
s | 比較項目が右分離符号付き外部10進数であることを指定する。 |
t | 比較項目が左分離符号付き外部10進数であることを指定する。 |
f | 比較項目が内部浮動小数点項目であることを指定する。 |
e | 比較項目が日付(英数字)であることを指定する。 |
比較項目の開始バイト位置を5桁以内の数字で指定します。開始バイト位置はレコードの先頭からのバイト位置(先頭を0とする)とします。開始バイト位置に指定できる値の範囲は,「0〜レコード長-1」です。
また,比較項目のバイト長を「1〜4,096」の範囲で指定します。
比較項目で指定した値と入力レコードの値を比較,選択する方法を指定します。比較演算子のオペランドを次の表に示します。
表11-9 比較演算子のオペランド(拡張SORTコマンド)
比較演算子 | 意味 |
---|---|
= | 条件値と等しい値の入力レコードを選択することを指定する。 |
!= | 条件値と異なる値の入力レコードを選択することを指定する。 |
> | 条件値より大きい値の入力レコードを選択することを指定する。 |
>= | 条件値より大きいか,または等しい値の入力レコードを選択することを指定する。 |
< | 条件値より小さい値の入力レコードを選択することを指定する。 |
<= | 条件値より小さいか,または等しい値の入力レコードを選択することを指定する。 |
比較の条件となる値を「c'文字条件値'」,「n'数値条件値'」,「x'16進数条件値'」または「d'日付条件値'」の形式で指定します。「c'文字条件値'」は比較項目が文字項目の場合,「n'数値条件値'」は比較項目が数値項目の場合に指定できます。また,「x'16進数条件値'」は比較項目が文字の場合でも数値の場合でも指定できます。「d'日付条件値'」は比較項目が日付項目の場合に指定できます。
指定できる条件値の長さを次の表に示します。
表11-10 指定できる条件値の長さ(拡張SORTコマンド)
項目 | 最小値 | 最大値 | 備考 |
---|---|---|---|
文字条件値 | 1 | 4,096 | − |
数値条件値※1 | 1 | 19 | 符号なしの場合は18 |
16進数条件値※2 | 2 | 8,192 | 指定できるのは偶数桁のデータだけ |
日付条件値※3 | 2 | 8 | − |
複数の選択条件式を指定する場合,論理演算子「AND」(論理積)または「OR」(論理和)を指定します。
選択条件式中に「AND」と「OR」が混在した場合は,「AND」を判定後,「OR」を判定します。「AND」と「OR」が混在した場合の処理の例を次に示します。
n+10-3△>△n'30'△AND△n+23-3△=△n'10'△ OR△n+10-3△<=△n'10'△AND△n+23-3△=△n'10'
この場合,次のうちどちらかの条件を満たしたレコードが選択されます。
ワークバッファとして使用するメモリの容量をKBまたはMB単位で指定します。ワークバッファサイズは,メモリ量と単位で指定します。
ワークバッファとして使用するメモリの容量を指定します。指定できる値を次の表に示します。
表11-11 メモリ量の指定範囲(拡張SORTコマンド)
SORTの種別 | レコード長※ | 指定範囲 |
---|---|---|
32ビット版 | 32,760バイト以下 | 128KB〜2,000MB |
32,760バイトより大きい | 256KB〜2,000MB | |
64ビット版 | 32,760バイト以下 | 256KB〜2,000MB |
32,760バイトより大きい | 384KB〜2,000MB |
この指定は省略できます。この指定を省略した場合,または最小メモリ量に満たない値が指定された場合は,1,024KBが設定されます。ただし,これらの場合で環境ファイルに初期値が設定されているときは,その値が設定されます。
なお,メモリ量の目安については,「17.1.1 ワークバッファサイズと処理時間」を参照してください。また,環境ファイルの設定方法については,「15. 環境ファイルの設定」を参照してください。
メモリ量の単位を,KBにするかMBにするか指定します。
また,単位を省略した場合は「KB(k)」が設定されます。
指定例を次に示します。
(例1)1,024KB→「work_size=1024k」または「work_size=1024」
(例2)2MB→「work_size=2m」
ソート実行に必要なソートキーを指定します。この指定は,実行上のオプションで「SORT」を指定した場合だけ有効となります。また,この指定は省略できません。
ソートキーのキー属性を「sort_key=」+オペランドの形式で指定します。キー属性のオペランドを次の表に示します。
表11-12 ソートキー属性のオペランド(拡張SORTコマンド)
オペランド | 内容 |
---|---|
r | キーの降順でソートすることを指定する。 |
c | キーが文字であることを指定する。 |
j | キーが文字(JIS8単位コード※)であることを指定する。 |
n | キーが符号付き固定小数点2進数であることを指定する。 |
m | キーが符号なし2進数であることを指定する。 |
p | キーが内部10進数であることを指定する。 |
z | キーが外部10進数であることを指定する。 |
x | キーが左符号付き外部10進数であることを指定する。 |
s | キーが右分離符号付き外部10進数であることを指定する。 |
t | キーが左分離符号付き外部10進数であることを指定する。 |
f | キーが内部浮動小数点であることを指定する。 |
e | キーが日付(英数字)であることを指定する。 |
「r」を指定しないときは,キーの昇順でソートされます。また,ソートキーにするデータの属性を「c,j,n,m,p,z,x,s,t,f,e」のパラメタのどれかで必ず指定してください。降順でソートする場合は,「rc」のようにつなげて指定します。なお,機能オプションに「v」を指定した場合,キーの属性を必ず「j」で指定してください。
キーの開始バイト位置を5桁以内の数字で指定します。開始バイト位置はレコードの先頭からのバイト位置(先頭を0とする)とします。開始バイト位置に指定できる値の範囲は,「0〜レコード長-1」です。
また,キーのバイト長を「1〜4,096」の範囲で指定します。
レコードを集約するための集約キーを指定します。この指定は,実行オプションで「sum」を指定した場合だけ有効となります。
複数指定する場合は,間をコンマ(,)で区切って指定します。
また,この指定は,「sort_key=ソートキー属性+キー位置-キー長」を指定した場合は省略できます。指定を省略した場合は「sort_key=」と同じ値が設定されます。どちらの指定もない場合はエラーとなります。
集約キーのキー属性を「sum_key=」+オペランドの形式で指定します。キー属性のオペランドを次の表に示します。
表11-13 集約キー属性のオペランド(拡張SORTコマンド)
オペランド | 内容 |
---|---|
c | キーが文字であることを指定する。 |
j | キーが文字(JIS8単位コード※)であることを指定する。 |
n | キーが符号付き固定小数点2進数であることを指定する。 |
m | キーが符号なし2進数であることを指定する。 |
p | キーが内部10進数であることを指定する。 |
z | キーが外部10進数であることを指定する。 |
x | キーが左符号付き外部10進数であることを指定する。 |
s | キーが右分離符号付き外部10進数であることを指定する。 |
t | キーが左分離符号付き外部10進数であることを指定する。 |
f | キーが内部浮動小数点であることを指定する。 |
e | キーが日付(英数字)であることを指定する。 |
キーの開始バイト位置を5桁以内の数字で指定します。開始バイト位置はレコードの先頭からのバイト位置(先頭を0とする)とします。開始バイト位置に指定できる値の範囲は,「0〜レコード長-1」です。
また,キーのバイト長を「1〜4,096」の範囲で指定します。
集約する項目を指定します。複数指定する場合は,間をコンマ(,)で区切って指定します。
無条件レコード抽出機能を使用する場合は,指定しません。無条件レコード抽出機能については,「2.4 無条件レコード抽出機能」を参照してください。
集約項目の属性を「sum_field=」+オペランドの形式で指定します。集約項目の属性のオペランドを次の表に示します。
表11-14 集約項目の属性のオペランド(拡張SORTコマンド)
オペランド | 内容 |
---|---|
n | 集約項目が符号付き固定小数点2進数であることを指定する。 |
m | 集約項目が符号なし2進数であることを指定する。 |
p | 集約項目が内部10進数であることを指定する。 |
z | 集約項目が外部10進数であることを指定する。 |
x | 集約項目が左符号付き外部10進数であることを指定する。 |
s | 集約項目が右分離符号付き外部10進数であることを指定する。 |
t | 集約項目が左分離符号付き外部10進数であることを指定する。 |
集約項目の開始バイト位置を5桁以内の数字で指定します。開始バイト位置はレコードの先頭からのバイト位置(先頭を0とする)とします。開始バイト位置に指定できる値の範囲は,「0〜レコード長-1」です。
また,集約項目のバイト長を「1〜19」の範囲で指定します。
SORTの出力先のファイル名を指定します。この指定は省略できます。省略した場合は,標準出力ファイルに出力します。
SORTの入力ファイル名を指定します。複数指定する場合は,間を「|」で区切って指定します。
また,この指定は省略できます。省略した場合は,標準入力ファイルが設定されます。
実行オプションでselectまたはsumを単独で指定した場合,出力ファイル名と同じ指定はできません。
All Rights Reserved. Copyright (C) 2008, 2016, Hitachi, Ltd.