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>' ] ]
Parâmetros¶
TERSE
Retorna a saída contendo apenas as seguintes colunas:
created_on
name
kind
database_name
schema_name
Observe que
kind
eschema_name
sempre exibemNULL
porquekind
não é aplicável para esquemas eschema_name
é redundante comname
.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'
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).
Notas de uso¶
Quando você especifica o escopo para
APPLICATION
ou para o banco de dados denominadoSNOWFLAKE
, a colunaowner
retornaSNOWFLAKE
como o proprietário do esquema denominadoLOCAL
. Por exemplo:SHOW SCHEMAS IN APPLICATION my_app; SHOW SCHEMAS IN DATABASE SNOWFLAKE;
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 exceder10000
. SeLIMIT 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 | +---------------------------------+--------------------+------------+------------+---------------+--------+-----------------------------------------------------------+---------+----------------+-----------------+--------+
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 | +---------------------------------+--------------------+------------+------------+---------------+--------+-----------------------------------------------------------+---------+----------------+---------------------------------+-----------------+----------+