SHOW SCHEMAS

Liste les schémas pour lesquels vous avez des privilèges d’accès, y compris les schémas détruits qui se trouvent encore dans la période de conservation Time Travel et qui, par conséquent, peuvent être restaurés. La commande peut être utilisée pour lister les schémas de la base de données actuelle/spécifiée ou de l’ensemble de votre compte.

La sortie renvoie les métadonnées et les propriétés du schéma, classées lexicographiquement par nom de base de données et de schéma. Ceci est important à noter si vous souhaitez filtrer les résultats à l’aide des filtres fournis.

Voir aussi :

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

Vue SCHEMATA (Information Schema)

Syntaxe

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

Paramètres

TERSE

Retourne une sortie ne contenant que les colonnes suivantes :

  • created_on

  • name

  • kind

  • database_name

  • schema_name

Notez que kind et schema_name affichent toujours NULL, car kind n’est pas applicable pour les schémas et schema_name est redondant avec name.

Par défaut : aucune valeur (toutes les colonnes sont incluses dans la sortie)

HISTORY

Inclut les schémas détruits qui n’ont pas encore été purgés (c’est-à-dire qu’ils sont toujours dans leurs périodes de conservation respectives de Time Travel). S’il existe plusieurs versions d’un schéma détruit, la sortie affiche une ligne pour chaque version. La sortie comprend également une colonne dropped_on supplémentaire, qui affiche les éléments suivants :

  • Date et horodatage (pour les schémas détruits)

  • NULL (pour les schémas actifs).

Aucune valeur (les schémas détruits ne sont pas inclus dans la sortie)

LIKE 'pattern'

(Facultatif) Filtre la sortie de commande par nom d’objet. Le filtre utilise une concordance de motif insensible à la casse avec prise en charge des caractères génériques SQL (% et _).

Par exemple, les motifs suivants donnent les mêmes résultats :

... LIKE '%testing%' ...
... LIKE '%TESTING%' ...

. Par défaut : aucune valeur (aucun filtrage n’est appliqué à la sortie).

IN { ACCOUNT | APPLICATION app_name | [ DATABASE ] [ db_name ] }

Spécifie la portée de la commande, qui détermine si la commande liste les enregistrements uniquement pour la base de données actuelle/spécifiée, ou pour l’ensemble de votre compte.

Le mot-clé APPLICATION n’est pas nécessaire, mais il précise la portée de l” Snowflake Native App nommée.

Le mot clé DATABASE n’est pas nécessaire ; vous pouvez définir la portée en spécifiant uniquement le nom de la base de données. De même, le nom de la base de données n’est pas nécessaire si la session utilise actuellement une base de données.

Par défaut : dépend si la session dispose actuellement d’une base de données en cours d’utilisation :

  • Base de données : DATABASE est la valeur par défaut (c’est-à-dire que la commande renvoie les objets que vous pouvez visualiser dans la base de données).

  • Aucune base de données : ACCOUNT est la valeur par défaut (c’est-à-dire que la commande renvoie les objets que vous pouvez visualiser dans votre compte).

STARTS WITH 'name_string'

(Facultatif) Filtre la sortie de commande en fonction des caractères qui apparaissent au début du nom de l’objet. La chaîne doit être délimitée par des guillemets simples et est sensible à la casse.

Par exemple, les chaînes suivantes renvoient des résultats différents :

... STARTS WITH 'B' ...
... STARTS WITH 'b' ...

. Par défaut : aucune valeur (aucun filtrage n’est appliqué à la sortie)

LIMIT rows [ FROM 'name_string' ]

(Facultatif) Limite le nombre maximum de lignes retournées, tout en permettant la « pagination » des résultats. Le nombre réel de lignes renvoyées peut être inférieur à la limite spécifiée. Par exemple, le nombre d’objets existants est inférieur à la limite spécifiée.

La sous-clause facultative FROM 'name_string' sert effectivement de « curseur » pour les résultats. Ceci permet de récupérer le nombre spécifié de lignes suivant la première ligne dont le nom d’objet correspond à la chaîne spécifiée :

  • La chaîne doit être délimitée par des guillemets simples et est sensible à la casse.

  • La chaîne n’a pas besoin d’inclure le nom complet de l’objet ; les noms partiels sont pris en charge.

Par défaut : aucune valeur (aucune limite n’est appliquée à la sortie)

Note

Pour les commandes SHOW qui prennent en charge les clauses FROM 'name_string' et STARTS WITH 'name_string', vous pouvez combiner ces deux clauses dans la même instruction. Cependant, les deux conditions doivent être remplies ou elles s’annulent mutuellement et aucun résultat n’est renvoyé.

De plus, les objets sont retournés dans l’ordre lexicographique par nom, donc FROM 'name_string' ne retourne que les lignes ayant une valeur lexicographique plus élevée que les lignes retournées par STARTS WITH 'name_string'

Par exemple :

  • ... STARTS WITH 'A' LIMIT ... FROM 'B' ne donnerait aucun résultat.

  • ... STARTS WITH 'B' LIMIT ... FROM 'A' ne donnerait aucun résultat.

  • ... STARTS WITH 'A' LIMIT ... FROM 'AB' donnerait des résultats (si des lignes correspondent aux chaînes d’entrée).

Notes sur l’utilisation

  • Lorsque vous spécifiez la portée soit APPLICATION soit la base de données nommée SNOWFLAKE, la colonne owner renvoie SNOWFLAKE en tant que propriétaire du schéma nommé LOCAL. Par exemple :

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

    La colonne renvoie owner :

    +-----+-------+-----+-----------+-----+
    | ... | name  | ... | owner     | ... |
    +-----+-------+-----+-----------+-----+
    | ... | LOCAL | ... | SNOWFLAKE | ... |
    +-----+-------+-----+-----------+-----+
    
  • L’exécution de la commande ne nécessite pas l’exécution d’un entrepôt en cours d’exécution.

  • La valeur pour LIMIT rows ne peut pas dépasser 10000. Si LIMIT rows est omis, la commande entraîne une erreur si le jeu de résultats est supérieur à 10 000 lignes.

    Pour afficher les résultats pour lesquels il existe plus de 10 000 enregistrements, incluez LIMIT rows ou interrogez la vue correspondante dans Schéma d’information de Snowflake.

  • Pour post-traiter la sortie de cette commande, vous pouvez utiliser la fonction RESULT_SCAN qui traite la sortie comme une table qui peut être interrogée.

Exemples

Afficher tous les schémas de la base de données courante, mytestdb, que vous avez le privilège d’afficher :

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

Afficher tous les schémas de la base de données courante, mytestdb, que vous avez le privilège d’afficher, y compris des schémas détruits (cet exemple se base sur les exemples 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