SnowConvert AI - Oracle - CURSOR¶
説明¶
危険
このセクションでは、Oracle 明示的カーソル の翻訳リファレンスについて説明します。Oracle カーソル変数 については、Snowflake Scriptingには同等のものはありません。
注釈
わかりやすくするため、出力コードの一部を省略しています。
Cursors are pointers that allow users to iterate through query results. For more information, see the Oracle Cursors documentation.
Oracleのカーソル構文¶
Cursor Definition
Cursor Open
Cursor Fetch
Cursor Close
Cursor Attributes
Cursor FOR Loop
Snowflake Scripting has support for cursors, however, they have fewer functionalities compared to Oracle. For more information, see the Snowflake Scripting cursors documentation.
Snowflakeスクリプトのカーソル構文¶
カーソル宣言
Cursor Open
Cursor Fetch
Cursor Close
Cursor FOR Loop
サンプルソースパターン¶
1.基本的なカーソルの例¶
Oracleのカーソルの例¶
Snowflakeスクリプトのカーソルの例¶
2.明示的Cursor For Loop¶
Oracleの明示的Cursor For Loopの例¶
Snowflakeスクリプトの明示的Cursor For Loopの例¶
3.暗黙的Cursor For Loop¶
Oracleの暗黙的Cursor For Loopの例¶
Snowflakeスクリプトの暗黙的Cursor For Loopの例¶
4.パラメーター化されたカーソル¶
「?」を使用できます宣言セクションのカーソルのフィルター条件で、バインド変数を定義します。カーソルを開いている間に、バインド変数を渡すために「USING <bind_variable_1 >」という構文を追加することができます。
以下は、カーソルでパラメーターを使用する際に起こりうるシナリオの例です。
4.1 基本的なカーソルのパラメーター化の例¶
Oracleのパラメーター化カーソルの例¶
Snowflakeのパラメーター化カーソルの例¶
4.2 複数の送信パラメーターを持つパラメーター化カーソル¶
Oracleのパラメーター化カーソルの例¶
Snowflakeのパラメーター化カーソルの例¶
4.3 クエリでプロシージャパラメーターを使用するパラメーター化カーソル¶
Oracleのパラメーター化カーソルの例¶
Snowflakeのパラメーター化カーソルの例¶
5.FetchとFor Loopでのカーソルの使用¶
カーソルは FOR ステートメントを使用して制御することができ、カーソルの各記録を処理することができます。一方、 FETCH ステートメントは、カーソルによって返された値を記録ごとに変数のセットに格納します。この変数は PLSQL 記録である可能性があります
5.1 Cursors For Loop¶
OracleのCursor For Loopの例¶
SnowflakeのCursor For Loopの例¶
5.2 Cursors Fetch¶
OracleのCursor Fetchの例¶
SnowflakeのCursor Fetchの例¶
既知の問題¶
1.RETURN 句はSnowflake Scriptingのカーソル宣言ではサポートされていません¶
Snowflake Scriptingのカーソル宣言にはこの句はありません。Oracleのカーソル定義からこれを削除することで、機能的等価性を得ることができます。
2.OPEN ステートメントは宣言された引数の値を渡すことはできません¶
カーソルに対して引数を宣言することができても、Snowflake Scriptingではその値を割り当てることはできません。最善の代替案は、バインド変数とともに USING 句を使用することです。
3.FETCH ステートメントで記録を使用することはできません¶
Snowflakeスクリプトは記録をサポートしていません。しかし、 OBJECT データ型と OBJECT_CONSTRUCT()メソッドを使って移行することは可能です。詳細は 記録の種類定義セクション を参照してください。
4.FETCH BULK COLLECT INTO 句はSnowflake Scriptingではサポートされていません¶
Snowflakeスクリプトは BULK COLLECT INTO 句をサポートしていません。しかし、 ARRAY_AGG を一時テーブルと共に使用し、カーソル情報に対応するデータを持つ新しい変数を構築することが可能です。詳細は コレクション一括操作セクション を参照してください。
5.Snowflake Scriptingにカーソル属性は存在しません¶
Oracleカーソルには、カーソルが開かれているかどうかやフェッチされた行数などのステータスをユーザーが確認できるさまざまな属性がありますが、カーソルステータスに関するこれらの属性はSnowflake Scriptingには存在しません。
6.カーソルのクエリはプロシージャの変数やパラメーターにアクセスできません¶
Oracleでは、カーソル宣言のクエリはプロシージャ変数とパラメーターにアクセスできますが、Snowflakeスクリプトではアクセスできません。これに代わる方法として、 USING 句をバインド変数と一緒に使う方法があります。
7. %NOTFOUND attribute is not supported in Snowflake Scripting Cursor¶
Oracleでは、開いているカーソルからの最初のフェッチの前に、cursor_name%NOTFOUND は、最後のフェッチが行を返せなかった場合は TRUE を返し、最後のフェッチが行を返した場合は FALSE を返します。Snowflake Scriptingはこの属性の使用をサポートしていません。代わりに、カーソル結果に割り当てられた変数に値が含まれているかどうかを検証することができます
CURSOR DECLARATION¶
注釈
関連性のないステートメント。
警告
このステートメントは関連性のない構文であるため、移行から削除されることに注意してください。つまり、Snowflakeでは必要ないということです。
注釈
わかりやすくするため、出力コードの一部を省略しています。
説明¶
このセクションでは、Oracleにおけるカーソル宣言の翻訳について説明します。詳細情報については、Oracleの プロシージャ と カーソル に関する以下のドキュメントを参照してください。
サンプルソースパターン¶
CURSOR DECLARATION¶
この例では、 CURSOR ステートメントが削除されていることに注意してください。これはSnowflakeをターゲットにした変換では関係のない構文です。
Oracle¶
Snowflake¶
既知の問題¶
問題は見つかりませんでした。
関連 EWIs¶
関連 EWIs はありません。
カーソル変数¶
カーソル変数と OPEN FOR ステートメントの翻訳リファレンス
注釈
わかりやすくするため、出力コードの一部を省略しています。
説明¶
カーソル変数は、1つのクエリに限定されない明示的なカーソルのようなものです。
Oracle構文¶
参照カーソルタイプ定義
カーソル変数宣言
OPEN FOR ステートメント
警告
Snowflake Scriptingはカーソル変数や OPEN FOR ステートメントと直接等価ではありませんが、さまざまな回避策でエミュレートし、機能的に等価にすることができます。
サンプルソースパターン¶
1.VARCHAR 変数内の動的 SQL を含む OPEN FOR ステートメント¶
Oracleの例¶
Snowflakeスクリプトの例¶
2.文字列リテラル内の動的 SQL を含む OPEN FOR ステートメント¶
Oracleの例¶
Snowflakeスクリプトの例¶
3.SELECT ステートメントを含む OPEN FOR ステートメント¶
Oracleの例¶
Snowflakeスクリプトの例¶
4.REF CURSOR 型で宣言されたカーソル変数¶
Oracleの例¶
Snowflakeスクリプトの例¶
5.USING 句を含む OPEN FOR ステートメント¶
Oracleの例¶
Snowflakeスクリプトの例¶
既知の問題¶
問題は見つかりませんでした。
関連 EWIs¶
SSC-EWI-0030:以下のステートメントでは、動的 SQL が使用されています。
SSC-EWI-0058:機能は現在、Snowflakeスクリプトではサポートされていません。
PARAMETRIZED CURSOR¶
パラメーター化カーソルはSnowflakeスクリプトではサポートされていません
注釈
わかりやすくするため、出力コードの一部を省略しています。
説明¶
Oracleは宣言されたカーソルのパラメーターをサポートします。しかし、Snowflake Scriptingはこの機能をサポートしていないため、カーソルの宣言や使用はできません。
コード例¶
Oracle¶
Snowflake¶
推奨事項¶
カーソル内のクエリにバインディングを使用し、
USING句でカーソルを開いてみてください。1つのカーソルで複数回使用されるパラメーターは、USING句で変数を複数回渡す必要があることに注意してください。
Snowflakeクエリ¶
バインディングを使用するカーソルを手動で変更します。
さらにサポートが必要な場合は、 snowconvert-support@snowflake.com までメールでお問い合わせください
関連 EWIs¶
SSC-PRF-0004:このステートメントには、cursor for loopが使用されています。
パラメーターまたはプロシージャ変数を使用するカーソルの回避策¶
説明¶
このセクションでは、カーソルのクエリ内でのカーソルパラメーターとプロシージャ変数の使用のシミュレーション方法について説明します。変数やパラメーターの名前は、 ? 記号を使ってバインディングに置き換えられます。そして、カーソルがオープンされた時、値は USING 句で渡されなければなりません。
注釈
ローカル変数を含むカーソル¶
使用される変数やプロシージャパラメーターのために、クエリのバインディングをカーソルで使用し、 USING 句でカーソルをオープンしてください。
Oracleのカーソル¶
Snowflakeスクリプトのカーソル¶
パラメーターを含むカーソル¶
使用されるパラメーターごとにクエリのバインディングをカーソルで使用し、 USING 句でカーソルを開きます。1つのカーソルで複数回使用されるパラメーターは、 USING 句で変数を複数回渡す必要があることに注意してください。
Oracleのカーソル¶
Snowflakeスクリプトのカーソル¶
関連 EWIs¶
SSC-PRF-0004:このステートメントには、cursor for loopが使用されています