SHOW DYNAMIC TABLES¶
Lista as tabelas dinâmicas para as quais você tem privilégios de acesso. O comando pode ser usado para listar tabelas dinâmicas para o banco de dados ou esquema atual/especificado, ou em toda a sua conta.
- Consulte também:
CREATE DYNAMIC TABLE, ALTER DYNAMIC TABLE, DESCRIBE DYNAMIC TABLE, DROP DYNAMIC TABLE, SHOW OBJECTS, Exibição TABLES (Information Schema)
Sintaxe¶
SHOW DYNAMIC TABLES [ LIKE '<pattern>' ]
[ IN
{
ACCOUNT |
DATABASE |
DATABASE <db_name> |
SCHEMA |
SCHEMA <schema_name> |
<schema_name>
}
]
[ STARTS WITH '<name_string>' ]
[ LIMIT <rows> [ FROM '<name_string>' ] ]
Parâmetros¶
LIKE 'pattern'
Opcionalmente, filtra a saída do comando pelo nome do objeto. O filtro utiliza correspondência de padrão que não diferencia maiúsculas e minúsculas, com suporte para caracteres curinga SQL (
%
e_
).Por exemplo, os seguintes padrões retornam os mesmos resultados:
... LIKE '%testing%' ...
... LIKE '%TESTING%' ...
. padrão: sem valor (nenhuma filtragem é aplicada à saída).
[ IN ... ]
Opcionalmente, especifica o escopo do comando. Especifique um dos seguintes:
ACCOUNT
Retorna registros para toda a conta.
DATABASE
, .DATABASE db_name
Retorna registros do banco de dados atual em uso ou de um banco de dados especificado (
db_name
).Se você especificar
DATABASE
semdb_name
e nenhum banco de dados estiver em uso, a palavra-chave não terá efeito sobre a saída.Nota
Usar comandos SHOW sem uma cláusula
IN
em um contexto de banco de dados pode resultar em menos resultados do que o esperado.Os objetos com o mesmo nome são exibidos apenas uma vez se não for usada a cláusula
IN
. Por exemplo, se a tabelat1
estiver emschema1
e a tabelat1
estiver emschema2
e ambas estiverem no escopo do contexto do banco de dados especificado (ou seja, o banco de dados selecionado é o pai deschema1
eschema2
), então SHOW TABLES exibirá apenas uma das tabelast1
.SCHEMA
, .SCHEMA schema_name
Retorna registros do esquema atual em uso ou de um esquema especificado (
schema_name
).SCHEMA
é opcional se um banco de dados estiver em uso ou se você especificar oschema_name
totalmente qualificado (por exemplo,db.schema
).Se nenhum banco de dados estiver em uso, a especificação
SCHEMA
não terá efeito sobre a saída.
Padrão: depende se a sessão tem ou não um banco de dados em uso no momento:
Banco de dados:
DATABASE
é o padrão (ou seja, o comando retorna os objetos nos quais você tem privilégios para visualizar no banco de dados).Sem banco de dados:
ACCOUNT
é o padrão (ou seja, o comando retorna os objetos que você tem privilégios de visualização em sua conta).
STARTS WITH 'name_string'
Opcionalmente, filtra a saída do comando com base nos caracteres que aparecem no início do nome do objeto. A cadeia de caracteres deve ser colocada entre aspas simples e faz distinção entre letras maiúsculas e minúsculas.
Por exemplo, as seguintes cadeias de caracteres retornam resultados diferentes:
... STARTS WITH 'B' ...
... STARTS WITH 'b' ...
. Padrão: sem valor (nenhuma filtragem é aplicada à saída)
LIMIT rows [ FROM 'name_string' ]
Opcionalmente, limita o número máximo de linhas retornadas, ao mesmo tempo em que permite a «paginação» dos resultados. O número real de linhas retornadas pode ser menor que o limite especificado. Por exemplo, o número de objetos existentes é menor que o limite especificado.
A subcláusula opcional
FROM 'name_string'
serve efetivamente como um “cursor” para os resultados. Isso permite obter o número especificado de linhas seguindo a primeira linha cujo nome do objeto corresponde à cadeia de caracteres especificada:A cadeia de caracteres deve ser colocada entre aspas simples e faz distinção entre letras maiúsculas e minúsculas.
A cadeia de caracteres não precisa incluir o nome completo do objeto; também é permitido usar nomes parciais.
Padrão: nenhum valor (nenhum limite é aplicado à saída)
Nota
Para comandos SHOW que oferecem suporte às cláusulas
FROM 'name_string'
eSTARTS WITH 'name_string'
, você pode combinar ambas as cláusulas na mesma instrução. No entanto, ambas as condições devem ser cumpridas ou elas se cancelam mutuamente e nenhum resultado é retornado.Além disso, os objetos são devolvidos em ordem lexicográfica por nome, portanto
FROM 'name_string'
só retorna linhas com um valor lexicográfico maior que as linhas retornadas porSTARTS WITH 'name_string'
.Por exemplo:
... STARTS WITH 'A' LIMIT ... FROM 'B'
não retornaria nenhum resultado.... STARTS WITH 'B' LIMIT ... FROM 'A'
não retornaria nenhum resultado.... STARTS WITH 'A' LIMIT ... FROM 'AB'
retornariam resultados (se alguma linha corresponder às cadeias de caracteres de entrada).
Requisitos de controle de acesso¶
A função usada para executar essa operação deve ter, no mínimo, os seguintes privilégios:
Privilégio |
Objeto |
Notas |
---|---|---|
SELECT |
As tabelas dinâmicas que você deseja listar. |
Alguns metadados ficam ocultos se você não tiver o privilégio MONITOR. Para obter mais informações, consulte Privilégios para visualizar os metadados de uma tabela dinâmica. |
O privilégio USAGE no banco de dados e no esquema pai é necessário para executar operações em qualquer objeto de um esquema.
Para instruções sobre como criar uma função personalizada com um conjunto específico de privilégios, consulte Criação de funções personalizadas.
Para informações gerais sobre concessões de funções e privilégios para executar ações de SQL em objetos protegíveis, consulte Visão geral do controle de acesso.
Notas de uso¶
Para SHOW uma tabela dinâmica, você deve estar usando uma função que tenha privilégio MONITOR na tabela.
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 a função RESULT_SCAN, que trata a saída como uma tabela que pode ser consultada. Você também pode usar o operador de canal para consultar a saída desse comando.
O valor de
LIMIT rows
não pode exceder10000
. SeLIMIT rows
for omitido, o comando resultará em um erro se o conjunto de resultados for maior que dez mil linhas.Para visualizar os resultados para os quais existem mais de dez mil registros, inclua
LIMIT rows
ou consulte a exibição correspondente em Snowflake Information Schema.
Saída¶
O comando de saída fornece propriedades de tabela e metadados nas seguintes colunas:
Coluna |
Descrição |
---|---|
|
Data e hora de criação da tabela dinâmica. |
|
Nome da tabela dinâmica. |
|
Banco de dados na qual a tabela dinâmica é armazenada. |
|
Esquema no qual a tabela dinâmica é armazenada. |
|
A(s) chave(s) de clustering da tabela dinâmica. |
|
Número de linhas na tabela. |
|
Número de bytes que serão digitalizados se a tabela dinâmica inteira for digitalizada em uma consulta. . . Observe que este número pode ser diferente do número de bytes físicos reais (ou seja, bytes armazenados em disco) para a tabela. |
|
Função proprietária da tabela dinâmica. |
|
A duração máxima que o conteúdo da tabela dinâmica deve ficar atrás do tempo real. |
|
|
|
Explicação do motivo pelo qual o modo de atualização foi escolhido. Se o Snowflake escolhesse |
|
Warehouse que fornece os recursos necessários para realizar as atualizações incrementais. |
|
Comentário para a tabela dinâmica. |
|
O texto do comando que criou esta tabela dinâmica (por exemplo, |
|
Se o clustering automático está ativado na tabela dinâmica. Atualmente não há suporte para tabelas dinâmicas. |
|
Exibe RUNNING para tabelas dinâmicas que estão agendando atualizações ativamente e SUSPENDED para tabelas dinâmicas suspensas. |
|
Carimbo de data/hora da última suspensão. |
|
TRUE se a tabela dinâmica for um clone; caso contrário, FALSE. |
|
TRUE se a tabela dinâmica for uma réplica; caso contrário, FALSE. |
|
TRUE se a tabela dinâmica for uma tabela dinâmica do Apache Iceberg™; caso contrário, FALSE. |
|
Carimbo de data/hora dos dados no(s) objeto(s) base incluído(s) na tabela dinâmica. |
|
O tipo de função que possui o objeto, por exemplo, |
Exemplos¶
Mostrar todas as tabelas dinâmicas com nomes que começam com product_
no esquema mydb.myschema
:
SHOW DYNAMIC TABLES LIKE 'product_%' IN SCHEMA mydb.myschema;