SHOW TRANSACTIONS

Lista todas as transações em execução. O comando pode ser usado para mostrar as transações do usuário atual ou de todos os usuários da conta.

Consulte também:

SHOW LOCKS

Sintaxe

SHOW TRANSACTIONS [ IN ACCOUNT ]
Copy

Parâmetros

IN ACCOUNT

Mostra todas as transações em todos os usuários da conta. Só pode ser usado por usuários com a função ACCOUNTADMIN (isto é, administradores de conta).

Saída

A saída do comando mostra metadados da transação nas seguintes colunas:

Coluna

Descrição

id

ID de transação (um inteiro de 64 bit assinado).

user

Usuário atual.

session

ID de sessão.

name

Nome definido pelo usuário ou nome gerado pelo sistema (UUID) para a transação.

started_on

Carimbo de data/hora que especifica quando a transação começou a ser executada.

state

Estado da transação: running.

scope

ID da operação que criou um procedimento armazenado em uma transação com escopo. 0 para transações sem escopo.

Notas de uso

  • As colunas que começam com o prefixo is_ retornam Y (sim) ou N (não).

  • O comando não precisa de um warehouse em funcionamento para ser executado.

  • O comando retorna um máximo de 10 mil registros para o tipo de objeto especificado, como ditado pelos privilégios de acesso para a função usada para executar o comando; quaisquer registros acima do limite 10 mil não são retornados, mesmo com um filtro aplicado.

    Para visualizar resultados para os quais existem mais de 10.000 registros, consulte a visualização correspondente (se houver) em Snowflake Information Schema.

  • Para pós-processar a saída deste comando, você pode usar a função RESULT_SCAN, que trata a saída como uma tabela que pode ser consultada.

  • A saída do comando inclui as IDs de todas as transações em execução. Estas IDs podem ser usadas como entrada para SYSTEM$ABORT_TRANSACTION para anular uma transação específica.

  • Um procedimento armazenado com uma transação pode ser chamado de dentro de outra transação. Essas transações são separadas, mas “com escopo”. Os valores na coluna scope são úteis para descobrir se duas transações estão no mesmo escopo. Para obter mais informações, consulte Transações com escopo.

Exemplo

Neste exemplo, duas sessões estão sendo executadas pelo mesmo usuário, com uma transação em andamento para cada sessão.

SHOW TRANSACTIONS;
Copy
+---------------------+---------+-----------------+--------------------------------------+-------------------------------+---------+-------+
|                  id | user    |         session | name                                 | started_on                    | state   | scope |
|---------------------+---------+-----------------+--------------------------------------+-------------------------------+---------+-------|
| 1721165674582000000 | CALIBAN | 186457423713330 | 551f494d-90ed-438d-b32b-1161396c3a22 | 2024-07-16 14:34:34.582 -0700 | running |     0 |
| 1721165584820000000 | CALIBAN | 186457423749354 | a092aa44-9a0a-4955-9659-123b35c0efeb | 2024-07-16 14:33:04.820 -0700 | running |     0 |
+---------------------+---------+-----------------+--------------------------------------+-------------------------------+---------+-------+