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:
Sintaxe¶
SHOW TRANSACTIONS [ IN ACCOUNT ]
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 de transação (um inteiro de 64 bit assinado). |
|
Usuário atual. |
|
ID de sessão. |
|
Nome definido pelo usuário ou nome gerado pelo sistema (UUID) para a transação. |
|
Carimbo de data/hora que especifica quando a transação começou a ser executada. |
|
Estado da transação: |
|
ID da operação que criou um procedimento armazenado em uma transação com escopo. |
Notas de uso¶
As colunas que começam com o prefixo
is_
retornamY
(sim) ouN
(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;
+---------------------+---------+-----------------+--------------------------------------+-------------------------------+---------+-------+
| 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 |
+---------------------+---------+-----------------+--------------------------------------+-------------------------------+---------+-------+