SnowConvert AI - Oracle - CURSOR¶
Descrição¶
Perigo
Esta seção aborda a referência de conversão para Cursor explícito do Oracle. Para as Variáveis de Cursor do Oracle, não há equivalente no Snowflake Scripting.
Nota
Algumas partes do código de saída foram omitidas por motivos de clareza.
Cursors are pointers that allow users to iterate through query results. For more information, see the Oracle Cursors documentation.
Sintaxe do Oracle Cursor¶
Definição de cursor
Cursor Open
Cursor Fetch
Cursor Close
Atributos de cursor
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.
Sintaxe de Snowflake Scripting Cursor¶
Declaração de cursor
Cursor Open
Cursor Fetch
Cursor Close
Cursor FOR Loop
Amostra de padrões da origem¶
1. Basic cursor example¶
Exemplo do Oracle Cursor¶
Exemplo de Snowflake Scripting Cursor¶
2. Explicit Cursor For Loop¶
Exemplo de Oracle Explicit Cursor For Loop¶
Exemplo de Snowflake Scripting Explicit Cursor For Loop¶
3. Implicit Cursor For Loop¶
Exemplo de Oracle Implicit Cursor For Loop¶
Exemplo de Snowflake Scripting Implicit Cursor For Loop¶
4. Parameterized Cursor¶
Você pode usar «?» Na condição de filtro do cursor, na seção de instrução, defina a variável bind. Ao abrir o cursor, podemos adicionar a sintaxe adicional «USING <bind_variable_1 >» para passar a variável bind.
Abaixo estão alguns exemplos de cenários que podem ocorrer no uso de parâmetros em cursores:
4.1 Exemplo parametrizado de cursor básico¶
Exemplo de cursor parametrizado Oracle¶
Exemplo de cursor parametrizado do Snowflake¶
4.2 Cursores parametrizados com vários parâmetros de envio¶
Exemplo de cursor parametrizado Oracle¶
Exemplo de cursor parametrizado do Snowflake¶
4.3 Cursores parametrizados com o uso de parâmetros de procedimento na consulta¶
Exemplo de cursor parametrizado Oracle¶
Exemplo de cursor parametrizado do Snowflake¶
5. Using Cursors In Fetch And For Loop¶
Os cursores podem ser controlados por meio do uso da instrução FOR, permitindo que cada registro de um cursor seja processado enquanto a instrução FETCH coloca, registro por registro, os valores retornados pelo cursor em um conjunto de variáveis, que podem ser registros PLSQL
5.1 Cursores For Loop¶
Exemplo de loop For com Oracle Cursor¶
Exemplo de Snowflake Cursor For Loop¶
5.2 Cursores Fetch¶
Exemplo de busca do Oracle Cursor¶
Exemplo de busca doSnowflake Cursor¶
Problemas conhecidos¶
1. RETURN clause is not supported in Snowflake Scripting Cursor Declaration¶
A Declaração de Cursor para Snowflake Scripting não inclui essa cláusula. Ele pode ser removido da definição do Oracle Cursor para obter equivalência funcional.
2. OPEN statement cannot pass values for declared arguments¶
Embora os argumentos possam ser declarados para um cursor, seus valores não podem ser atribuídos no Snowflake Scripting. A melhor alternativa é usar a cláusula USING com variáveis bind.
3. FETCH statement cannot use records¶
O Script Snowflake não oferece suporte a registros. No entanto, é possível migrá-las usando o tipo de dados OBJECT e o método OBJECT_CONSTRUCT(). Para obter mais informações, consulte a Seção de definição do tipo de registro.
4. FETCH BULK COLLECT INTO clause is not supported in Snowflake Scripting¶
O Script Snowflake não oferece suporte à cláusula BULK COLLECT INTO. Entretanto, é possível usar ARRAY_AGG junto com uma tabela temporal para construir uma nova variável com os dados correspondentes às informações do cursor. Para obter mais informações, consulte a Seção de operações em massa de coleção.
5. Cursor attributes do not exist in Snowflake Scripting¶
Os cursores Oracle têm diferentes atributos que permitem ao usuário verificar seu status, como se ele está aberto ou a quantidade de linhas obtidas; no entanto, esses atributos referentes ao status do cursor não existem no Snowflake Scripting.
6. The cursor’s query does not have access to the procedure’s variables and parameters¶
No Oracle, a consulta na instrução do cursor tem acesso às variáveis e parâmetros do procedimento, mas, no Script Snowflake, não tem. A alternativa para isso é usar a cláusula USING com variáveis de vinculação.
7. %NOTFOUND attribute is not supported in Snowflake Scripting Cursor¶
No Oracle ele pode ser usado, antes da primeira busca de um cursor aberto, cursor_name%NOTFOUND retorna TRUE se a última busca não retornou uma linha, ou FALSE se a última busca retornou uma linha. O Snowflake Scripting não oferece suporte ao uso desse atributo; em vez disso, ele pode ser validado se a variável atribuída ao resultado do cursor contiver valores
CURSOR DECLARATION¶
Nota
Instrução não relevante.
Aviso
Observe que esta instrução foi removida da migração; porque é uma sintaxe não relevante. Isso significa que não é necessária no Snowflake.
Nota
Algumas partes do código de saída foram omitidas por motivos de clareza.
Descrição¶
Esta seção explica a conversão da declaração de cursores no Oracle. Para obter mais informações, consulte a documentação a seguir sobre procedimentos e cursores no Oracle.
Amostra de padrões da origem¶
CURSOR DECLARATION¶
Observe que, neste exemplo, a instrução CURSOR foi excluída. Essa é uma sintaxe não relevante na transformação direcionada ao Snowflake.
Oracle¶
Snowflake¶
Problemas conhecidos¶
Não foram encontrados problemas.
EWIs relacionados¶
Sem EWIs relacionados.
Variáveis de cursor¶
Referência de tradução para variáveis de cursor e a instrução OPEN FOR
Nota
Algumas partes do código de saída foram omitidas por motivos de clareza.
Descrição¶
Uma variável de cursor é como um cursor explícito que não se limita a uma consulta.
(Declaração de variável de cursor da referência de linguagem Oracle PL/SQL)
Sintaxe do Oracle¶
Definição do tipo de cursor de referência
Declaração da variável do cursor
Instrução OPENFOR
Aviso
O Snowflake Scripting não tem equivalência direta com as variáveis de cursor e a instrução OPEN FOR. No entanto, eles podem ser emulados com diferentes soluções alternativas para obter equivalência funcional.
Amostra de padrões da origem¶
1. OPEN FOR statement with dynamic SQL inside a VARCHAR variable¶
Exemplo de Oracle¶
Exemplo de Script Snowflake¶
2. OPEN FOR statement with dynamic SQL inside a string literal.¶
Exemplo de Oracle¶
Exemplo de Script Snowflake¶
3. OPEN FOR statement with SELECT statement¶
Exemplo de Oracle¶
Exemplo de Script Snowflake¶
4. Cursor Variable declared with REF CURSOR type¶
Exemplo de Oracle¶
Exemplo de Script Snowflake¶
5. OPEN FOR statement with USING clause¶
Exemplo de Oracle¶
Exemplo de Script Snowflake¶
Problemas conhecidos¶
Não foram encontrados problemas.
EWIs relacionados¶
SSC-EWI-0030: A instrução abaixo utiliza SQL dinâmico.
SSC-EWI-0058: A funcionalidade é atualmente incompatível com o Script Snowflake.
PARAMETRIZED CURSOR¶
O cursor parametrizado não é compatível com o Snowflake Scripting
Nota
Algumas partes do código de saída foram omitidas por motivos de clareza.
Descrição¶
O Oracle oferece suporte a parâmetros para cursores declarados. No entanto, o Snowflake Scripting não oferece suporte a esse recurso, portanto, a declaração e o uso do cursor não são possíveis.
Exemplo de código¶
Oracle¶
Snowflake¶
Recomendações¶
Tente usar associações para a consulta no cursor e abra o cursor com a cláusula
USING. Lembre-se de que um parâmetro que é usado várias vezes em um único cursor pode exigir a passagem da variável várias vezes na cláusulaUSING.
Consulta do Snowflake¶
Altere manualmente o cursor para usar as associações.
Se precisar de mais suporte, envie um e-mail para snowconvert-support@snowflake.com
EWIs relacionados¶
SSC-PRF-0004: Esta instrução tem usos do cursor para o loop.
Solução alternativa para cursores que usam parâmetros ou variáveis de procedimento¶
Descrição¶
Esta seção descreve como simular o uso de parâmetros de cursor e variáveis de procedimento dentro da consulta de um cursor. O nome das variáveis ou parâmetros é substituído por associações usando o sinal ?. Em seguida, quando o cursor for aberto, os valores deverão ser passados com a cláusula USING.
Nota
Cursor com variáveis locais¶
Use as vinculações para a consulta no cursor para o parâmetro de variável ou procedimento usado e abra o cursor com a cláusula USING.
Oracle Cursor¶
Snowflake Scripting Cursor¶
Cursor com parâmetros¶
Use associações para a consulta no cursor para cada parâmetro usado e abra o cursor com a cláusula USING. Lembre-se de que um parâmetro que é usado várias vezes em um único cursor pode exigir a passagem da variável várias vezes na cláusula USING.
Oracle Cursor¶
Snowflake Scripting Cursor¶
EWIs relacionados¶
SSC-PRF-0004: Esta instrução faz uso de cursor for loop.