SHOW SCHEMAS

Lista os esquemas para os quais você tem privilégios de acesso, incluindo esquemas descartados que ainda estão dentro do período de retenção do Time Travel e, portanto, podem ser recuperados. O comando pode ser usado para listar esquemas para o banco de dados atual/especificado, ou em toda a sua conta.

A saída retorna metadados e propriedades do esquema, ordenados lexicograficamente pelo nome do banco de dados e do esquema. Isso é importante se você deseja filtrar os resultados usando os filtros fornecidos.

Consulte também:

CREATE SCHEMA , ALTER SCHEMA , DESCRIBE SCHEMA , DROP SCHEMA , UNDROP SCHEMA

Exibição SCHEMATA (Information Schema)

Sintaxe

SHOW [ TERSE ] SCHEMAS
  [ HISTORY ]
  [ LIKE '<pattern>' ]
  [ IN { ACCOUNT | APPLICATION <app_name> | DATABASE [ <db_name> ] } ]
  [ STARTS WITH '<name_string>' ]
  [ LIMIT <rows> [ FROM '<name_string>' ] ]
Copy

Parâmetros

TERSE

Retorna a saída contendo apenas as seguintes colunas:

  • created_on

  • name

  • kind

  • database_name

  • schema_name

Observe que kind e schema_name sempre exibem NULL porque kind não é aplicável para esquemas e schema_name é redundante com name.

Padrão: sem valor (todas as colunas estão incluídas na saída)

HISTORY

Inclui esquemas descartados que ainda não foram purgados (ou seja, ainda estão dentro de seus respectivos períodos de retenção do Time Travel). Se existirem várias versões de um esquema descartado, a saída exibe uma linha para cada versão. A saída também inclui uma coluna adicional dropped_on, que exibe:

  • Data e carimbo de data/hora (para esquemas descartados)

  • NULL (para esquemas ativos).

Padrão: sem valor (esquemas descartados não são incluídos na saída)

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 | APPLICATION app_name | [ DATABASE ] [ db_name ] }

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

A palavra-chave APPLICATION não é obrigatória, mas especifica o escopo do Snowflake Native App nomeado.

A palavra-chave DATABASE não é necessária; você pode definir o escopo especificando apenas o nome do banco de dados. Da mesma forma, o nome do banco de dados não é necessário se a sessão atualmente tiver um banco de dados em uso.

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

Notas de uso

  • Quando você especifica o escopo para APPLICATION ou para o banco de dados denominado SNOWFLAKE, a coluna owner retorna SNOWFLAKE como o proprietário do esquema denominado LOCAL. Por exemplo:

    SHOW SCHEMAS IN APPLICATION my_app;
    SHOW SCHEMAS IN DATABASE SNOWFLAKE;
    
    Copy

    A coluna owner retorna:

    +-----+-------+-----+-----------+-----+
    | ... | name  | ... | owner     | ... |
    +-----+-------+-----+-----------+-----+
    | ... | LOCAL | ... | SNOWFLAKE | ... |
    +-----+-------+-----+-----------+-----+
    
  • 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.

Exemplos

Mostrar todos os esquemas no banco de dados atual, mytestdb, que você tem privilégios para visualizar:

SHOW SCHEMAS;

+---------------------------------+--------------------+------------+------------+---------------+--------+-----------------------------------------------------------+---------+----------------+-----------------+--------+
| created_on                      | name               | is_default | is_current | database_name | owner  | comment                                                   | options | retention_time | owner_role_type | budget |
|---------------------------------+--------------------+------------+------------+---------------+--------+-----------------------------------------------------------+---------+----------------+-----------------+--------+
| Fri, 13 May 2016 17:58:37 -0700 | INFORMATION_SCHEMA | N          | N          | MYTESTDB      |        | Views describing the contents of schemas in this database |         |              1 | ROLE            | NULL   |
| Wed, 25 Feb 2015 16:16:54 -0800 | PUBLIC             | N          | Y          | MYTESTDB      | PUBLIC |                                                           |         |              1 | ROLE            | NULL   |
+---------------------------------+--------------------+------------+------------+---------------+--------+-----------------------------------------------------------+---------+----------------+-----------------+--------+
Copy

Mostrar todos os esquemas no banco de dados atual, mytestdb, que você tem privilégios para visualizar, incluindo esquemas descartados (este exemplo se baseia nos exemplos DROP SCHEMA):

SHOW SCHEMAS HISTORY;

+---------------------------------+--------------------+------------+------------+---------------+--------+-----------------------------------------------------------+---------+----------------+---------------------------------+-----------------+----------+
| created_on                      | name               | is_default | is_current | database_name | owner  | comment                                                   | options | retention_time | dropped_on                      | owner_role_type | budget   |
|---------------------------------+--------------------+------------+------------+---------------+--------+-----------------------------------------------------------+---------+----------------+---------------------------------+-----------------+----------+
| Fri, 13 May 2016 17:59:50 -0700 | INFORMATION_SCHEMA | N          | N          | MYTESTDB      |        | Views describing the contents of schemas in this database |         |              1 | NULL                            |                 | NULL     |
| Wed, 25 Feb 2015 16:16:54 -0800 | PUBLIC             | N          | Y          | MYTESTDB      | PUBLIC |                                                           |         |              1 | NULL                            | ROLE            | NULL     |
| Tue, 17 Mar 2015 16:42:29 -0700 | MYSCHEMA           | N          | N          | MYTESTDB      | PUBLIC |                                                           |         |              1 | Fri, 13 May 2016 17:25:32 -0700 | ROLE            | MYBUDGET |
+---------------------------------+--------------------+------------+------------+---------------+--------+-----------------------------------------------------------+---------+----------------+---------------------------------+-----------------+----------+
Copy