ヘッダーをスキップ
Oracle® OLAP DMLリファレンス
11gリリース2 (11.2)
B61346-03
  ドキュメント・ライブラリへ移動
ライブラリ
製品リストへ移動
製品
目次へ移動
目次
索引へ移動
索引

前
 
次
 

OUTFILE

OUTFILEコマンドによって、文のテキスト出力をファイルにリダイレクトできます。

構文

OUTFILE {EOF | TRACEFILE | [APPEND] file-name [NOCACHE] [NLS_CHARSET charset-exp]}

パラメータ

EOF

現行の出力ファイルは閉じられ、出力がデフォルトの出力ファイルにリダイレクトされます。

TRACEFILE

TRACEFILEUNITオプションによって識別されるOracleトレース・ファイルに出力が送信されることを指定します。

APPEND

出力を既存のディスク・ファイルの末尾に追加することを指定します。この引数を省略すると、ファイルの現在の内容は新しい出力によって置き換えられます。

file-name

出力が書き込まれるファイルの名前を表すテキスト式。そのファイルがカレント・ディレクトリにない場合、ファイルの名前にディレクトリ・オブジェクトの名前を含める必要があります。


注意:

ディレクトリ・オブジェクトはデータベースで定義され、ディレクトリおよびディレクトリ内のファイルへのアクセスを制御します。CDA文を使用して、カレント・ディレクトリ・オブジェクトを特定および指定できます。使用するデータベース・ユーザー名で読取りおよび書込み可能なファイルがあるディレクトリ・オブジェクトへのアクセス権については、Oracle DBAに問い合せてください。

NOCACHE

行が生成されるたびにOracle OLAPが出力ファイルに行を書き込むことを指定します。このキーワードを指定しなかった場合、Oracle OLAPでは、ファイルのI/Oアクティビティを軽減するため、テキストの保存およびファイルへの書込みが定期的に実行されます。NOCACHEキーワードを指定するとパフォーマンスが大幅に低下しますが、各行が出力ファイルに即座に記録されます。この引数はfile-nameの後に指定する必要があります。

NLS_CHARSET charset-exp

file-nameによって指定されるファイルにテキスト・データを書き込む際にOracle OLAPが使用するキャラクタ・セットを指定しますが、これによって、Oracle OLAPはデータをそのキャラクタ・セットに正確に変換できます。この引数はfile-nameの後に指定する必要があります。この引数を省略すると、Oracle OLAPはNLS_LANGオプションに記録されているデータベース・キャラクタ・セットでデータをファイルに書き込みます。

使用上の注意

PERMIT_READまたはPERMIT_WRITEプログラムのファイル出力

PERMIT_READプログラムまたはPERMIT_WRITEプログラムの内容は、ファイル出力時に空になります。これらのプログラムの内容を正常にアナリティック・ワークスペースにコピーしたりアナリティック・ワークスペースからコピーするには、OUTFILEを使用する前にプログラムの名前を変更し、INFILEを使用してプログラムをアナリティック・ワークスペースにコピーした後に、再度PERMIT_READまたはPERMIT_WRITEという名前を付けます。

現行の出力ファイル識別子

OUTFILE文は実行されるたびに、最初の手順として現行の出力ファイルを閉じます。OUTFILEによってディスク上の新しいファイルが開かれると、このファイルにはファイル・ユニット番号として不定のINTEGERが自動的に割り当てられます。現行ファイル・ユニット番号は、OUTFILEUNITオプションで保持されます。

出力ファイルへの追加

出力をあるファイルに送信後、2番目のファイルに送信すると、最初のファイルは開いたままにはなりません。最初のファイルへの出力の送信を再開するには、別のOUTFILE文を実行してAPPEND file-name句を指定する必要があります。

出力ファイルの自動クローズ

OUTFILE file-nameを使用して出力をディスク・ファイルへ送ると、現在開いている出力ファイルはすべて閉じられます。この閉じる動作は、新しいファイルが実際には開いていない場合にも実行されます(OUTFILE文に無効なfile-nameを指定した場合と同様です)。

ページング・オプションとリダイレクトされる出力

ページング・オプションは、各ページのテキスト出力の編成を制御します。このオプションには、BMARGIN、LINENUM、LINELEFT、PAGESIZE、PAGENUM、PAGEPRG、PAGING、TMARGINおよびLSIZEがあります。これらのページング・オプションは、出力ファイルごとに個別の値を持ちます。ディスク・ファイルへの出力を制御するためにページング・オプションを設定した場合、OUTFILE文を再度使用して出力をリダイレクトするまで、その新しい値が有効です。コマンドを再度使用すると、ページング・オプションはデフォルト値に戻ります。したがって、ディスク・ファイルに対してページング・オプションを特定の値にする場合、通常、OUTFILE文を実行してからそのオプションを設定します。

現行の出力ファイルとデフォルトの出力ファイル

現行の出力ファイルとは、REPORTやDESCRIBEなど、テキストを生成する文の出力先となるファイルです。OUTFILE文を使用せずに出力をファイルに送ると、Oracle OLAPはデフォルトの出力ファイルを使用します。

例10-68 レポートの出力ファイルへの送信

この例では、REPORT文の出力を出力ファイルに送信します。

OUTFILE 'budget.rpt'
REPORT budget
OUTFILE EOF 

例10-69 出力のファイルへの送信

year.end.salesという名前のプログラムがあり、このプログラムが作成するレポートをファイルに保存するとします。次のコマンドを入力してレポートをファイルに書き込みます。この例では、userfilesがディレクトリ・オブジェクトであり、yearend.txtがファイル名です。

OUTFILE 'userfiles/yearend.txt'
year.end.sales
OUTFILE EOF

これにより、ファイルにyear.end.salesレポートが格納されます。OUTFILEのAPPENDキーワードを使用すると、同じファイルにレポートを追加できます。year.end.expensesという名前の別のプログラムがあるとします。次のコマンドを使用して、このプログラムのレポートをファイルに追加します。APPENDを指定しないでOUTFILE文を実行すると、このexpensesレポートが上書きされます。

OUTFILE APPEND 'userfiles/yearend.txt'
year.end.expenses
OUTFILE EOF