SHOW LOCKS¶
Lista todas as transações em execução que têm bloqueios de recursos. O comando pode ser usado para mostrar bloqueios para o usuário atual em todas as sessões do usuário ou para todos os usuários da conta.
Para obter mais informações sobre transações e bloqueio de recursos, consulte Transações.
- Consulte também:
Sintaxe¶
SHOW LOCKS [ IN ACCOUNT ]
Parâmetros¶
IN ACCOUNT
Retorna todos os bloqueios em todos os usuários da conta. Este parâmetro só se aplica quando executado por usuários com a função ACCOUNTADMIN (administradores de conta).
Para todas as outras funções, a função só mostra bloqueios em todas as sessões para o usuário atual.
Saída¶
A saída de comando mostra metadados de bloqueio nas seguintes colunas:
Coluna |
Descrição |
---|---|
|
Um nome de tabela totalmente qualificado ou um ID de transação. |
|
|
|
ID de transação (um inteiro de 64 bit assinado). |
|
Carimbo de data/hora que especifica quando a transação começou a ser executada. |
|
Status atual da transação: |
|
Carimbo de data/hora que especifica quando o bloqueio foi adquirido. |
|
Identificador interno/gerado pelo sistema para a instrução SQL. |
|
ID de sessão (visível somente para usuários com a função ACCOUNTADMIN). |
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 para todas as transações em execução com bloqueios nos recursos. Estas IDs podem ser usadas como entrada para SYSTEM$ABORT_TRANSACTION para anular uma transação específica.
Para tabelas híbridas, este comando exibe um bloqueio somente se uma transação estiver bloqueada ou bloqueando outra transação.
Exemplos¶
Neste exemplo, uma transação está mantendo um bloqueio na tabela padrão especificada (a tabela nomeada na coluna resource
).
SHOW LOCKS;
+---------------------------+------------+---------------------+-------------------------------+---------+-------------------------------+--------------------------------------+
| resource | type | transaction | transaction_started_on | status | acquired_on | query_id |
|---------------------------+------------+---------------------+-------------------------------+---------+-------------------------------+--------------------------------------|
| CALIBAN_DB.PUBLIC.WEATHER | PARTITIONS | 1721330303831000000 | 2024-07-18 12:18:23.831 -0700 | HOLDING | 2024-07-18 12:18:49.832 -0700 | 01b5c1c6-0002-8691-0000-a9950068a0c6 |
+---------------------------+------------+---------------------+-------------------------------+---------+-------------------------------+--------------------------------------+
Neste exemplo, uma transação está mantendo um bloqueio em nível de linha em uma tabela híbrida. Outra transação está aguardando esse bloqueio.
SHOW LOCKS;
+---------------------+------+---------------------+-------------------------------+---------+-------------+--------------------------------------+
| resource | type | transaction | transaction_started_on | status | acquired_on | query_id |
|---------------------+------+---------------------+-------------------------------+---------+-------------+--------------------------------------|
| 1721165584820000000 | ROW | 1721165584820000000 | 2024-07-16 14:33:04.820 -0700 | HOLDING | NULL | |
| 1721165584820000000 | ROW | 1721165674582000000 | 2024-07-16 14:34:34.582 -0700 | WAITING | NULL | 01b5b715-0002-852b-0000-a99500665352 |
+---------------------+------+---------------------+-------------------------------+---------+-------------+--------------------------------------+