SHOW DATABASES

Liste les bases de données pour lesquelles vous avez des privilèges d’accès sur l’ensemble de votre compte, y compris les bases de données détruites qui se situent encore dans la période de conservation de Time Travel et qui, par conséquent, peuvent être rétablies.

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

Astuce

Outre SQL, vous pouvez également utiliser d’autres interfaces, telles que Snowflake REST APIs, Snowflake Python APIs et Snowflake CLI. Voir Interfaces alternatives.

Voir aussi :

CREATE DATABASE , ALTER DATABASE , DESCRIBE DATABASE , DROP DATABASE , UNDROP DATABASE

Vue DATABASES (Information Schema)

Syntaxe

SHOW [ TERSE ] DATABASES [ HISTORY ] [ LIKE '<pattern>' ]
                                     [ STARTS WITH '<name_string>' ]
                                     [ LIMIT <rows> [ FROM '<name_string>' ] ]
                                     [ WITH PRIVILEGES <object_privilege> [ , <object_privilege> [ , ... ] ] ]
Copy

Paramètres

TERSE

(Facultatif) Retourne une sortie ne contenant que les colonnes suivantes :

  • created_on

  • name

  • kind

  • database_name

  • schema_name

Notez que kind, database_name et schema_name affichent toujours NULL, car les colonnes ne sont pas applicables pour les bases de données.

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

HISTORY

(Facultatif) Inclut les bases de données détruites qui n’ont pas encore été purgées (c’est-à-dire qu’elles sont toujours dans leurs périodes de conservation respectives de Time Travel). S’il existe plusieurs versions d’une base de données détruite, 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 bases de données détruites).

  • NULL (pour les bases de données actives).

Par défaut : aucune valeur (les bases de données détruites ne sont pas incluses 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).

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 encadrée de 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 encadrée de 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).

WITH PRIVILEGES object_privilege [ , object_privilege [ , ... ] ]

Limite éventuellement les lignes aux objets pour lesquels le rôle actif de l’utilisateur actuel a reçu tous les privilèges spécifiés dans la liste sur l’objet.

Si un privilège <objet> CREATE est inclus dans la liste des privilèges, la commande exclut les objets pour lesquels des privilèges ont été accordés aux rôles secondaires. C’est parce que seul le rôle principal a l’autorisation de créer des objets. Pour plus d’informations, voir Autorisation par le biais d’un rôle primaire et de rôles secondaires.

OBJECT_VISIBILITY

Cette nouvelle colonne est annexée aux vues existantes et est réservée pour une utilisation future. Pour plus d’informations, voir Vues DATABASES et SCHEMATA et commandes SHOW DATABASES et SHOW SCHEMAS : Nouvelle colonne dans la sortie.

Notes sur l’utilisation

  • Les paramètres HISTORY et WITH PRIVILEGES s’excluent mutuellement ; ils ne peuvent pas tous deux être utilisés dans la même instruction.

  • Pour une base de données personnelle, la valeur de la colonne kind est PERSONAL DATABASE.

  • La commande ne nécessite pas l’exécution d’un entrepôt en cours d’exécution.

  • La commande ne renvoie que les objets pour lesquels le rôle actuel de l’utilisateur s’est vu accorder au moins un privilège d’accès.

  • Le privilège d’accès MANAGE GRANTS permet implicitement à son titulaire de voir tous les objets du compte. Par défaut, seuls l’administrateur du compte (utilisateurs avec le rôle ACCOUNTADMIN) et l’administrateur de sécurité (utilisateurs avec le rôle SECURITYADMIN) ont le privilège MANAGE GRANTS.

  • Pour post-traiter la sortie de cette commande, vous pouvez utiliser la fonction RESULT_SCAN qui traite la sortie sous forme de table à interroger. Vous pouvez également utiliser l”opérateur de canal pour interroger la sortie de cette commande.

  • La valeur de 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 à dix mille lignes.

    Pour afficher les résultats pour lesquels il existe plus de dix mille enregistrements, vous devez inclure LIMIT rows ou interroger la vue correspondante dans Schéma d’information de Snowflake.

Exemples

Afficher toutes les bases de données que vous avez le privilège de consulter dans votre compte :

SHOW DATABASES;
Copy
+---------------------------------+-----------+------------+------------+--------+--------+---------+---------+----------------+----------+-----------------+-------------------+
| created_on                      | name      | is_default | is_current | origin | owner  | comment | options | retention_time | kind     | owner_role_type | OBJECT_VISIBILITY |
|---------------------------------+-----------+------------+------------+--------+--------+---------+---------+----------------+----------|-----------------|-------------------|
| Tue, 17 Mar 2015 16:57:04 -0700 | MYTESTDB  | N          | Y          |        | PUBLIC |         |         | 1              | STANDARD | ROLE            | NULL              |
| Wed, 25 Feb 2015 17:30:04 -0800 | SALES1    | N          | N          |        | PUBLIC |         |         | 1              | STANDARD | ROLE            | NULL              |
| Fri, 13 Feb 2015 19:21:49 -0800 | DEMO1     | N          | N          |        | PUBLIC |         |         | 1              | STANDARD | ROLE            | NULL              |
+---------------------------------+-----------+------------+------------+--------+--------+---------+---------+----------------+----------+-----------------+-------------------+

Afficher toutes les bases de données que vous avez le privilège de consulter dans le système, y compris les bases de données détruites (cet exemple s’appuie sur les exemples DROP DATABASE) :

SHOW DATABASES HISTORY;
Copy
+---------------------------------+-----------+------------+------------+--------+--------+---------+---------+----------------+---------------------------------+----------+-----------------+-------------------+
| created_on                      | name      | is_default | is_current | origin | owner  | comment | options | retention_time | dropped_on                      | kind     | owner_role_type | OBJECT_VISIBILITY |
|---------------------------------+-----------+------------+------------+--------+--------+---------+---------+----------------+---------------------------------|----------|-----------------|-------------------|
| Tue, 17 Mar 2015 16:57:04 -0700 | MYTESTDB  | N          | Y          |        | PUBLIC |         |         | 1              | [NULL]                          | STANDARD | ROLE            | NULL              |
| Wed, 25 Feb 2015 17:30:04 -0800 | SALES1    | N          | N          |        | PUBLIC |         |         | 1              | [NULL]                          | STANDARD | ROLE            | NULL              |
| Fri, 13 Feb 2015 19:21:49 -0800 | DEMO1     | N          | N          |        | PUBLIC |         |         | 1              | [NULL]                          | STANDARD | ROLE            | NULL              |
| Wed, 25 Feb 2015 16:16:54 -0800 | MYTESTDB2 | N          | N          |        | PUBLIC |         |         | 1              | Fri, 13 May 2016 17:35:09 -0700 | STANDARD | ROLE            | NULL              |
+---------------------------------+-----------+------------+------------+--------+--------+---------+---------+----------------+---------------------------------+----------+-----------------+-------------------+

Afficher toutes les bases de données pour lesquelles vous avez obtenu les privilèges USAGE et MODIFY sur :

SHOW DATABASES WITH PRIVILEGES USAGE, MODIFY;
Copy
+-------------------------------+-----------------------------------------------------------+------------+------------+-----------------------------------------------------------+--------------+---------+---------+----------------+-------------------+-----------------+-------------------+
| created_on                    | name                                                      | is_default | is_current | origin                                                    | owner        | comment | options | retention_time | kind              | owner_role_type | OBJECT_VISIBILITY |
|-------------------------------+-----------------------------------------------------------+------------+------------+-----------------------------------------------------------+--------------+---------+---------+----------------+-------------------+-----------------|-------------------|
| 2023-01-27 14:33:11.417 -0800 | BOOKS_DB                                                  | N          | N          |                                                           | DATA_ADMIN   |         |         | 1              | STANDARD          | ROLE            | NULL              |
| 2023-09-15 15:22:51.111 -0700 | TEST_DB                                                   | N          | N          |                                                           | ACCOUNTADMIN |         |         | 4              | STANDARD          | ROLE            | NULL              |
| 2023-08-18 13:33:01.024 -0700 | SNOWFLAKE                                                 | N          | N          | SNOWFLAKE.ACCOUNT_USAGE                                   |              |         |         | 0              | APPLICATION       |                 | NULL              |
+-------------------------------+-----------------------------------------------------------+------------+------------+-----------------------------------------------------------+--------------+---------+---------+----------------+-------------------+-----------------+-------------------+

Interfaces alternatives