SHOW ICEBERG TABLES

Lista as tabelas 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 [ <db_name> ] | SCHEMA [ <schema_name> ] } ]
                                  [ STARTS WITH '<name_string>' ]
                                  [ LIMIT <rows> [ FROM '<name_string>' ] ]
Copy

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  ACCOUNT | DATABASE [ db_name ] | SCHEMA [ schema_name ]

Especifica opcionalmente o escopo do comando, que determina se o comando lista registros apenas para o banco de dados ou esquema atual/especificado ou em toda a sua conta:

Se você especificar a palavra-chave ACCOUNT, então o comando recuperará os registros de todos os esquemas em todos os bancos de dados da conta atual.

Se você especificar a palavra-chave DATABASE, então:

  • Se você especificar um db_name, então o comando recupera registros para todos os esquemas do banco de dados especificado.

  • Se você não especificar um db_name, então:

    • Se houver um banco de dados atual, então o comando recuperará os registros de todos os esquemas do banco de dados atual.

    • Se não houver um banco de dados atual, então o comando recuperará registros para todos os bancos de dados e esquemas da conta.

Se você especificar a palavra-chave SCHEMA, então:

  • Se você especificar um nome de esquema qualificado (por exemplo, my_database.my_schema), então o comando recuperará registros para o banco de dados e esquema especificado.

  • Se você especificar um schema_name não qualificado, então:

    • Se houver um banco de dados atual, então o comando recupera os registros para o esquema especificado no banco de dados atual.

    • Se não houver um banco de dados atual, então o comando exibe o erro SQL compilation error: Object does not exist, or operation cannot be performed.

  • Se você não especificar um schema_name, então:

    • Se houver um banco de dados atual, então:

      • Se houver um esquema atual, então o comando recupera registros para o esquema atual no banco de dados atual.

      • Se não houver um esquema atual, então o comando recupera os registros de todos os esquemas no banco de dados atual.

    • Se não houver um banco de dados atual, então o comando recupera os registros de todos os bancos de dados e todos os esquemas da conta.

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. O comando retorna os objetos nos quais você tem privilégios para visualizar no banco de dados atual.

  • Nenhum banco de dados: ACCOUNT é o padrão. O comando retorna os objetos nos quais você tem privilégios para visualizar 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 delimitada entre aspas simples e há distinção entre 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 delimitada entre aspas simples e há distinção entre 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' e STARTS 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 por STARTS 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

Uma função usada para executar este comando SQL deve ter os seguintes privilégios no mínimo:

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.

Observe que operar em qualquer objeto de um esquema também requer o privilégio USAGE no banco de dados e esquema principais.

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 valor de LIMIT rows não pode exceder 10000. Se LIMIT rows for omitido, o comando resulta em um erro se o conjunto de resultados for maior que 10.000 linhas.

    Para visualizar os resultados para os quais existem mais de 10.000 registros, incluir LIMIT rows ou consultar a exibição correspondente no 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.

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

created_on

Data e hora de criação da tabela.

name

Nome da tabela.

database_name

Banco de dados na qual a tabela é armazenada.

schema_name

Esquema no qual a tabela é armazenada.

owner

Função proprietária da tabela.

external_volume_name

Nome do volume externo onde os dados e metadados da tabela Iceberg são armazenados.

catalog_name

Nome do objeto de integração de catálogo associado à tabela Iceberg quando a tabela não é gerenciada pelo Snowflake. SNOWFLAKE quando a tabela é gerenciada pelo Snowflake.

iceberg_table_type

Tipo de tabela Iceberg. UNMANAGED se a tabela não for gerenciada pelo Snowflake. Caso contrário, NOT ICEBERG.

catalog_table_name

Nome da tabela conforme reconhecida pelo catálogo.

catalog_namespace

Namespace de catálogo para a tabela. O namespace definido quando a tabela foi criada. Caso contrário, o namespace padrão associado à integração do catálogo usado pela tabela.

file_path

Caminho relativo do local EXTERNAL_VOLUME até os metadados da tabela e arquivos de dados. Definido como BASE_LOCATION quando você cria determinados tipos de tabelas Iceberg.

can_write_metadata

Significa se o Snowflake pode gravar metadados no local especificado por file_path.

comment

Comentário para a tabela.

name_mapping

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.

owner_role_type

O tipo de função que possui o objeto, ROLE ou DATABASE_ROLE. . Se um Snowflake Native App possuir o objeto, o valor será APPLICATION. . Snowflake retornará NULL se você excluir o objeto porque um objeto excluído não tem função de proprietário.

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"
        ]
      }
    ]
  }
]
Copy

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;
Copy

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

Y se a tabela for uma tabela Iceberg; caso contrário, N.