SHOW ICEBERG TABLES¶
Lista as Tabelas Apache Iceberg™ para as quais você tem privilégios de acesso.
O comando pode ser usado para listar tabelas Iceberg para o banco de dados ou esquema atual/especificado, ou em toda a sua conta.
Este comando retorna colunas de saída diferentes de SHOW TABLES. A saída retorna metadados e propriedades da tabela Iceberg, ordenados lexicograficamente por banco de dados, esquema e nome da tabela Iceberg (consulte Saída neste tópico para descrições das colunas de saída). Isso é importante se você deseja filtrar os resultados usando os filtros fornecidos.
Observe que este tópico se refere às tabelas Iceberg simplesmente como “tabelas”, exceto onde a especificação de tabelas Iceberg evita confusão.
- Consulte também:
CREATE ICEBERG TABLE , DROP ICEBERG TABLE , DESCRIBE ICEBERG TABLE , ALTER ICEBERG TABLE , SHOW TABLES
Sintaxe¶
SHOW [ TERSE ] [ ICEBERG ] TABLES [ LIKE '<pattern>' ]
[ IN
{
ACCOUNT |
DATABASE |
DATABASE <database_name> |
SCHEMA |
SCHEMA <schema_name> |
<schema_name>
}
]
[ STARTS WITH '<name_string>' ]
[ LIMIT <rows> [ FROM '<name_string>' ] ]
Parâmetros¶
TERSE
Opcionalmente, retorna apenas um subconjunto das colunas de saída:
created_on
name
kind
O valor da coluna
kind
é sempre ICEBERG TABLE.database_name
schema_name
Padrão: sem valor (todas as colunas estão incluídas na saída)
ICEBERG
Retorna apenas tabelas Iceberg.
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 |
Tabela Iceberg |
Para ver uma tabela Iceberg específica na saída de SHOW ICEBERG TABLES, uma função deve ter o privilégio SELECT nessa tabela. |
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¶
Se uma conta (ou banco de dados ou esquema) tiver um grande número de tabelas Iceberg, então a busca de toda a conta (ou banco de dados ou esquema) pode consumir uma quantidade significativa de recursos de computaçã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 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¶
Nota
O esquema de saída a seguir é para o comando SHOW ICEBERG TABLES. Para obter informações sobre a saída de SHOW TABLES, consulte Identificação de tabelas Iceberg com SHOW TABLES (neste tópico).
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. |
|
Nome da tabela. |
|
Banco de dados na qual a tabela é armazenada. |
|
Esquema no qual a tabela é armazenada. |
|
Função proprietária da tabela. |
|
Nome do volume externo onde os dados e metadados da tabela Iceberg são armazenados. |
|
Nome do objeto de integração de catálogo associado à tabela Iceberg quando a tabela não é gerenciada pelo Snowflake. |
|
Tipo de tabela Iceberg. |
|
Nome da tabela conforme reconhecida pelo catálogo. |
|
Para tabelas gerenciadas externamente, o namespace que foi definido quando a tabela foi criada. Se não for definido no nível da tabela, o namespace padrão associado à integração do catálogo usado pela tabela. Para tabelas gerenciadas pelo Snowflake que você sincroniza com o Snowflake Open Catalog, esse campo não é obrigatório, portanto o valor é |
|
Caminho relativo do local |
|
Significa se o Snowflake pode gravar metadados no local especificado por |
|
Comentário para a tabela. |
|
Lista de objetos com informações sobre colunas da tabela que usam a projeção de coluna. Para obter mais informações, consulte name_mapping. |
|
O tipo de função que possui o objeto, por exemplo |
|
Indica o nome da integração do catálogo do Snowflake Open Catalog com o qual a tabela do Apache Iceberg™ gerenciada pelo Snowflake é sincronizada. Se a tabela não for sincronizada com o Snowflake Open Catalog ou não for gerenciada pelo Snowflake, o valor será |
|
O status de atualização automática de uma tabela Iceberg gerenciada externamente. Essa coluna exibe os mesmos resultados para a tabela que a função SYSTEM$AUTO_REFRESH_STATUS. |
name_mapping¶
A coluna de saída name_mapping
fornece informações sobre colunas da tabela que usam a projeção de coluna.
Se uma tabela não contiver nenhuma coluna com um mapeamento de nome associado, a coluna de saída terá um valor de [NULL]
. Caso contrário, o valor será uma lista de objetos, onde cada objeto corresponde a uma coluna que possui um mapeamento de nome associado (às vezes chamado de campo mapeado). Cada objeto pode conter as três propriedades a seguir:
field-id
: o ID do campo Iceberg.names
: uma lista de cadeias de caracteres de nomes para o campo.fields
: uma lista de mapeamentos de campo para os campos filhos de colunas struct, map ou list.
Por exemplo:
[
{
"field-id": 1,
"names": [
"id",
"record_id"
]
},
{
"field-id": 2,
"names": [
"data"
]
},
{
"field-id": 3,
"names": [
"location"
],
"fields": [
{
"field-id": 4,
"names": [
"latitude",
"lat"
]
},
{
"field-id": 5,
"names": [
"longitude",
"long"
]
}
]
}
]
Nota
Os IDs do campo podem ser não consecutivos se uma coluna (ou um campo em uma coluna de tipo estruturado) não tiver um mapeamento de nome associado.
Exemplos¶
Mostrar todas as tabelas Iceberg cujo nome começa com glue
que você tem privilégios para ver no esquema tpch.public
:
SHOW ICEBERG TABLES LIKE 'glue%' IN tpch.public;
Identificação de tabelas Iceberg com SHOW TABLES¶
A saída do comando SHOW TABLES possui uma coluna que indica se uma tabela é uma tabela Iceberg. Esta coluna aparece além das colunas de saída SHOW TABLES normais.
A coluna tem o seguinte nome e valores possíveis:
Nome da coluna |
Valores |
---|---|
is_iceberg |
|