SnowConvert AI - Oracle - CURSOR¶
Description¶
Danger
Cette section couvre la référence de traduction pour le curseur explicite Oracle. Les variables de curseur Oracle n’ont pas d’équivalent dans Snowflake Scripting.
Note
Certaines parties du code de sortie sont omises pour des raisons de clarté.
Cursors are pointers that allow users to iterate through query results. For more information, see the Oracle Cursors documentation.
Syntaxe du curseur Oracle¶
Définition du curseur
Curseur Open
Curseur Fetch
Curseur Close
Attributs du curseur
Curseur 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.
Syntaxe du curseur Snowflake Scripting¶
Déclaration de curseurs
Curseur Open
Curseur Fetch
Curseur Close
Curseur FOR Loop
Modèles d’échantillons de sources¶
1. Basic cursor example¶
Exemple de curseur Oracle¶
Exemple de curseur Snowflake Scripting¶
2. Explicit Cursor For Loop¶
Exemple de curseur explicite For Loop Oracle¶
Exemple de curseur explicite For Loop Snowflake Scripting¶
3. Implicit Cursor For Loop¶
Exemple de curseur implicite For Loop Oracle¶
Exemple de curseur implicite For Loop Snowflake Scripting¶
4. Parameterized Cursor¶
Vous pouvez utiliser « ? » Dans la condition de filtre du curseur, dans la section de déclaration, définissez la variable de liaison. Lors de l’ouverture du curseur, nous pouvons ajouter la syntaxe supplémentaire « USING <bind_variable_1 > » pour passer la variable de liaison.
Vous trouverez ci-dessous quelques exemples de scénarios qui peuvent se produire lors de l’utilisation de paramètres dans les curseurs :
4.1 Exemple paramétré de curseur de base¶
Exemple de curseur paramétré par Oracle¶
Exemple de curseur paramétré par Snowflake¶
4.2 Curseurs paramétrés avec plusieurs paramètres d’envoi¶
Exemple de curseur paramétré par Oracle¶
Exemple de curseur paramétré par Snowflake¶
4.3 Curseurs paramétrés avec utilisation de paramètres de procédure dans la requête¶
Exemple de curseur paramétré par Oracle¶
Exemple de curseur paramétré par Snowflake¶
5. Using Cursors In Fetch And For Loop¶
Les curseurs peuvent être contrôlés à l’aide de l’instruction FOR, ce qui permet de traiter chaque enregistrement d’un curseur pendant que l’instruction FETCH place, enregistrement par enregistrement, les valeurs retournées par le curseur dans un ensemble de variables, qui peuvent être des enregistrements PLSQL
5.1 Curseurs For Loop¶
Exemple de curseur For Loop Oracle¶
Exemple de curseur For Loop Snowflake¶
5.2 Curseurs Fetch¶
Exemple de curseur Fetch Oracle¶
Exemple de curseur Fetch Snowflake¶
Problèmes connus¶
1. RETURN clause is not supported in Snowflake Scripting Cursor Declaration¶
La déclaration de curseur pour Snowflake Scripting n’inclut pas cette clause. Elle peut être supprimée de la définition du curseur Oracle pour obtenir une équivalence fonctionnelle.
2. OPEN statement cannot pass values for declared arguments¶
Même si des arguments peuvent être déclarés pour un curseur, leurs valeurs ne peuvent pas être affectées dans Snowflake Scripting. La meilleure alternative consiste à utiliser la clause USING avec des variables de liaison.
3. FETCH statement cannot use records¶
L’exécution de scripts Snowflake ne prend pas en charge les enregistrements. Cependant, il est possible de les migrer en utilisant le type de données OBJECT et la méthode OBJECT_CONSTRUCT (). Pour plus d’informations, consultez la section Définition du type d’enregistrement.
4. FETCH BULK COLLECT INTO clause is not supported in Snowflake Scripting¶
L’exécution de scripts Snowflake ne prend pas en charge la clause BULK COLLECT INTO. Toutefois, il est possible d’utiliser ARRAY_AGG avec une table temporelle pour construire une nouvelle variable avec les données correspondant aux informations du curseur. Pour plus d’informations, consultez la [section des opérations de collecte en masse](collects-and-records.md#collecting-buk- Operations).
5. Cursor attributes do not exist in Snowflake Scripting¶
Les curseurs Oracle ont différents attributs qui permettent à l’utilisateur de vérifier leur statut, par exemple s’ils sont ouverts ou le nombre de lignes extraites. Cependant, ces attributs concernant le statut du curseur n’existent pas dans Snowflake Scripting.
6. The cursor’s query does not have access to the procedure’s variables and parameters¶
Dans Oracle, la requête dans la déclaration du curseur a accès aux variables et paramètres de la procédure, mais dans l’exécution de scripts Snowflake, ce n’est pas le cas. La solution consiste à utiliser la clause USING avec des variables de liaison.
7. %NOTFOUND attribute is not supported in Snowflake Scripting Cursor¶
Dans Oracle, il est possible d’utiliser, avant la première extraction d’un curseur ouvert, curseur_name%NOTFOUND qui renvoie TRUE si la dernière extraction n’a pas renvoyé de ligne, ou FALSE si la dernière extraction a renvoyé une ligne. Snowflake Scripting ne prend pas en charge l’utilisation de cet attribut ; en revanche, il peut être validé si la variable assignée au résultat du curseur contient des valeurs
CURSOR DECLARATION¶
Note
Instruction non pertinente.
Avertissement
Notez que cette instruction a été supprimée de la migration ; car la syntaxe n’est pas pertinente. Cela signifie qu’elle n’est pas requise dans Snowflake.
Note
Certaines parties du code de sortie sont omises pour des raisons de clarté.
Description¶
Cette section explique la traduction de la déclaration des curseurs dans Oracle. Pour plus d’informations, consultez la documentation suivante sur les procédures et les curseurs dans Oracle.
Modèles d’échantillons de sources¶
CURSOR DECLARATION¶
Notez que dans cet exemple, l’instruction CURSOR a été supprimée. Il s’agit d’une syntaxe non pertinente dans la transformation ciblée sur Snowflake.
Oracle¶
Snowflake¶
Problèmes connus¶
Aucun problème n’a été constaté.
EWIs connexes¶
Pas d’EWIs connexes.
Variables de curseur¶
Référence de traduction pour les variables de curseur et l’instruction OPEN FOR
Note
Certaines parties du code de sortie sont omises pour des raisons de clarté.
Description¶
Une variable de curseur est comme un curseur explicite qui n’est pas limité à une seule requête.
(Référence linguistique Oracle PL/SQL Déclaration de variable de curseur)
Syntaxe Oracle¶
Définition du type de curseur Ref
Déclaration des variables de curseur
Instruction OPEN FOR
Avertissement
Snowflake Scripting n’a pas d’équivalence directe avec les variables de curseur et l’instruction OPEN FOR, mais il est possible de les émuler avec différentes solutions de contournement pour obtenir une équivalence fonctionnelle.
Modèles d’échantillons de sources¶
1. OPEN FOR statement with dynamic SQL inside a VARCHAR variable¶
Exemple Oracle¶
Exemple d’exécution de scripts Snowflake¶
2. OPEN FOR statement with dynamic SQL inside a string literal.¶
Exemple Oracle¶
Exemple d’exécution de scripts Snowflake¶
3. OPEN FOR statement with SELECT statement¶
Exemple Oracle¶
Exemple d’exécution de scripts Snowflake¶
4. Cursor Variable declared with REF CURSOR type¶
Exemple Oracle¶
Exemple d’exécution de scripts Snowflake¶
5. OPEN FOR statement with USING clause¶
Exemple Oracle¶
Exemple d’exécution de scripts Snowflake¶
Problèmes connus¶
Aucun problème n’a été constaté.
EWIs connexes¶
SSC-EWI-0030: L’instruction ci-dessous a des utilisations de Dynamic SQL.
SSC-EWI-0058: La fonctionnalité n’est pas prise en charge actuellement par l’exécution de scripts Snowflake.
PARAMETRIZED CURSOR¶
Le curseur paramétré n’est pas pris en charge par l’exécution de scripts Snowflake
Note
Certaines parties du code de sortie sont omises pour des raisons de clarté.
Description¶
Oracle prend en charge les paramètres pour les curseurs déclarés. Cependant, le support Snowflake Scripting ne prend pas en charge cette fonction, de sorte que la déclaration et l’utilisation du curseur ne sont pas possibles.
Exemple de code¶
Oracle¶
Snowflake¶
Recommandations¶
Essayez d’utiliser des liens pour la requête dans le curseur et ouvrez le curseur avec la clause
USING. Gardez à l’esprit qu’un paramètre utilisé plusieurs fois sur un même curseur peut nécessiter de passer la variable plusieurs fois dans la clauseUSING.
Requête Snowflake.¶
Modifiez manuellement le curseur pour utiliser les liaisons.
Si vous avez besoin de plus d’assistance, vous pouvez nous envoyer un e-mail à snowconvert-support@snowflake.com
EWIs connexes¶
SSC-PRF-0004: Cette instruction a des utilisations de curseur For Loop.
Solution de contournement pour les curseurs utilisant des paramètres ou des variables de procédure¶
Description¶
Cette section décrit comment simuler l’utilisation des paramètres du curseur et des variables de procédure dans la requête d’un curseur. Le nom des variables ou des paramètres est remplacé par des liaisons à l’aide du signe ?. Ensuite, lorsque le curseur est ouvert, les valeurs doivent être transmises avec la clause USING.
Note
Curseur avec variables locales¶
Utilisez des liaisons pour la requête dans le curseur pour la variable ou le paramètre de procédure utilisé et ouvrez le curseur avec la clause USING.
Curseur Oracle¶
Curseur d’exécution de scripts Snowflake¶
Curseur avec paramètres¶
Utilisez des liaisons pour la requête dans le curseur pour chaque paramètre utilisé et ouvrez le curseur avec la clause USING. Gardez à l’esprit qu’un paramètre utilisé plusieurs fois sur un même curseur peut nécessiter de passer la variable plusieurs fois dans la clause USING.
Curseur Oracle¶
Curseur d’exécution de scripts Snowflake¶
EWIs connexes¶
SSC-PRF-0004: Cette instruction a des utilisations de curseur For Loop