SHOW DYNAMIC TABLES

Répertorie les tables dynamiques pour lesquelles vous avez des privilèges d’accès. La commande peut être utilisée pour répertorier les tables dynamiques de la base de données ou du schéma actuel/spécifié ou pour l’ensemble de votre compte.

Voir aussi :

CREATE DYNAMIC TABLE, ALTER DYNAMIC TABLE, DESCRIBE DYNAMIC TABLE, DROP DYNAMIC TABLE

SHOW OBJECTS

Vue TABLES (Information Schema)

Syntaxe

SHOW DYNAMIC TABLES [ LIKE '<pattern>' ]
                    [ IN
                      {
                           ACCOUNT              |

                           DATABASE             |
                           DATABASE <db_name>   |

                           SCHEMA               |
                           SCHEMA <schema_name> |
                           <schema_name>
                      }
                    ]
                    [ STARTS WITH '<name_string>' ]
                    [ LIMIT <rows> [ FROM '<name_string>' ] ]
Copy

Paramètres

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

Spécifie de manière facultative la portée de la commande. Spécifie l’un des éléments suivants :

ACCOUNT

Renvoie les enregistrements pour l’ensemble du compte.

DATABASE, . DATABASE db_name

Renvoie les enregistrements pour la base de données en cours d’utilisation ou pour une base de données spécifiée (db_name).

Si vous spécifiez DATABASE sans db_name et qu’aucune base de données n’est utilisée, le mot-clé n’a aucun effet sur la sortie.

SCHEMA, . SCHEMA schema_name, . schema_name

Renvoie les enregistrements pour le schéma en cours d’utilisation ou un schéma spécifié (schema_name).

SCHEMA est facultatif si une base de données est utilisée ou si vous spécifiez le schema_name complet (par exemple, db.schema).

Si aucune base de données n’est utilisée, spécifier SCHEMA n’a aucun effet sur la sortie.

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

  • Pour afficher (SHOW) une table dynamique, vous devez utiliser un rôle disposant du privilège MONITOR sur la table.

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

Sortie

La sortie de commande fournit les propriétés des tables et les métadonnées dans les colonnes suivantes :

Colonne

Description

created_on

Date et heure de création de la table dynamique.

name

Nom de la table dynamique.

reserved

database_name

Base de données dans laquelle la table dynamique est stockée.

schema_name

Schéma dans laquelle la table dynamique est stockée.

cluster_by

rows

Nombre de lignes de la table.

bytes

Nombre d’octets qui seront analysés si la table dynamique entière est analysée dans une requête. . . Notez que ce nombre peut être différent du nombre d’octets physiques réels (c’est-à-dire les octets stockés sur disque) pour la table.

owner

Rôle auquel appartient la table dynamique.

target_lag

Durée maximale de retard du contenu de la table dynamique par rapport au temps réel.

refresh_mode

INCREMENTAL si la table dynamique utilise des actualisations incrémentielles, ou FULL si elle recalcule l’ensemble de la table à chaque actualisation.

refresh_mode_reason

Explication du choix du mode d’actualisation FULL. NULL si le mode d’actualisation n’est pas FULL.

warehouse

Entrepôt qui fournit les ressources nécessaires pour effectuer les actualisations incrémentielles.

comment

Commentaire pour la table dynamique.

text

Le texte de la commande qui a créé cette table dynamique (par exemple, CREATE DYNAMIC TABLE ...).

automatic_clustering

Si le clustering automatique est activé sur la table dynamique. Non pris en charge actuellement pour les tables dynamiques.

scheduling_state

Affiche RUNNING pour les tables dynamiques qui planifient activement des actualisations et SUSPENDED pour les tables dynamiques suspendues.

last_suspended_on

Horodatage de la dernière suspension.

is_clone

TRUE si la table dynamique a été clonée, sinon FALSE.

is_replica

TRUE si la table dynamique est un réplica, sinon FALSE.

data_timestamp

Horodatage des données du ou des objets de base qui sont incluses dans la table dynamique.

owner_role_type

Type de rôle qui possède l’objet, soit ROLE ou DATABASE_ROLE. . Si une Snowflake Native App est propriétaire de l’objet, la valeur est APPLICATION. . Snowflake renvoie NULL si vous supprimez l’objet, car un objet supprimé n’a pas de rôle propriétaire.

Exemples

Affichez toutes les tables dynamiques dont le nom commence par product_ dans le schéma mydb.myschema :

SHOW DYNAMIC TABLES LIKE 'product_%' IN SCHEMA mydb.myschema;
Copy