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:

SHOW TRANSACTIONS

Sintaxe

SHOW LOCKS [ IN ACCOUNT ]
Copy

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

resource

Um nome de tabela totalmente qualificado ou um ID de transação.

type

PARTITIONS (para bloqueios de tabela padrão) ou ROW (para bloqueios de tabela híbrida).

transaction

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

transaction_started_on

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

status

Status atual da transação: HOLDING ou WAITING.

acquired_on

Carimbo de data/hora que especifica quando o bloqueio foi adquirido.

query_id

Identificador interno/gerado pelo sistema para a instrução SQL.

session

ID de sessão (visível somente para usuários com a função ACCOUNTADMIN).

Notas de uso

  • 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.

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

  • O comando retorna apenas objetos para os quais a função atual do usuário atual recebeu pelo menos um privilégio de acesso.

  • O privilégio de acesso MANAGE GRANTS permite implicitamente que seu titular consulte todos os objetos da conta. Por padrão, somente o administrador de conta (usuários com a função ACCOUNTADMIN) e o administrador de segurança (usuários com a função SECURITYADMIN) têm o privilégio MANAGE GRANTS.

  • Para pós-processar a saída deste comando, você pode usar o operador de canal (->>) ou a função RESULT_SCAN. Ambos os constructos tratam a saída como um conjunto de resultados que você pode consultar.

    Por exemplo, é possível usar o operador de canal ou a função RESULT_SCAN para selecionar colunas específicas da saída do comando SHOW ou filtrar as linhas.

    Quando você fizer referência a colunas de saída, use identificadores entre aspas duplas para os nomes das colunas. Por exemplo, para selecionar a coluna de saída type, especifique SELECT "type".

    Você deve usar identificadores entre aspas duplas porque os nomes das colunas de saída para os comandos SHOW estão em minúsculas. As aspas duplas garantem que os nomes das colunas na lista SELECT ou na cláusula WHERE correspondam aos nomes das colunas na saída do comando SHOW que foi verificada.

  • O comando retorna um máximo de dez mil registros para o tipo de objeto especificado, conforme ditado pelos privilégios de acesso da função usada para executar o comando. Todos os registros acima do limite de dez mil registros não são retornados, mesmo com um filtro aplicado.

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

Exemplos

Neste exemplo, uma transação está mantendo um bloqueio na tabela padrão especificada (a tabela nomeada na coluna resource).

SHOW LOCKS;
Copy
+---------------------------+------------+---------------------+-------------------------------+---------+-------------------------------+--------------------------------------+
| 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;
Copy
+---------------------+------+---------------------+-------------------------------+---------+-------------+--------------------------------------+
| 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 |
+---------------------+------+---------------------+-------------------------------+---------+-------------+--------------------------------------+