FETCH
FETCHステートメントはSQLスクリプトで使用され、開いているカーソルから1行を読み取ります。
構文
FETCH <cursor> INTO <varList>
変数リストは、変数のリスト (プロジェクションの数と同じ数) または適切なスキーマを持つ ROW 変数にすることができます。 ROW については、「DECLARE CURSOR 型変数」を参照してください。
備考
| • | <varList> は SELECT INTO 句のように機能します。 (「 SELECT INTO」を参照してください。) |
| • | 開いていないカーソルからフェッチすることは違法です。 |
| • | 最後の行を超えてフェッチしても、エラーは発生しません。変数は変更されず、FOUND 属性は FALSE に設定されます。詳細については、Cursor の属性を参照してください。 |
| • | フェッチの方向を NEXT または FIRST に指定できます。これらの単語は、次のようにキーワード FROM と一緒に使用する必要があります。 |
FETCH NEXT FROM x INTO i;FETCH FIRST FROM x INTO i;
フェッチ方向が指定されていない場合、NEXTがデフォルトです。
方向がNEXTの場合、フェッチは通常どおりに動作します。つまり、現在の行のデータをターゲット変数にフェッチします。
方向として FIRST を指定する場合、カーソルは SCROLL カーソルでなければなりません。それ以外の場合は、エラーが発生します。「DECLARE CURSOR 型変数」を参照してください。
指定された方向がFIRSTの場合、カーソルは最初の行に再配置され、最初の行のデータがターゲット変数に配置されます。
エラー
次の表に、FETCHステートメントの実行中に発生する可能性のあるエラーを示します。
|
エラーメッセージ |
原因 |
|
初期化されていないカーソル |
カーソル変数が使用されますが、フェッチ時に初期化されません。 |
|
カーソルが開いていません |
フェッチが試行されたときにカーソルが閉じられました。 |