SHOW STREAMS

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

La sortie renvoie les métadonnées et les propriétés du flux, classées lexicographiquement par nom de base de données, de schéma et de flux (voir Sortie dans ce chapitre pour lire la description des colonnes de sortie). Ceci est important à noter si vous souhaitez filtrer les résultats à l’aide des filtres fournis.

Voir aussi :

CREATE STREAM , ALTER STREAM , DROP STREAM , DESCRIBE STREAM

Syntaxe

SHOW [ TERSE ] STREAMS [ LIKE '<pattern>' ]
                       [ IN { ACCOUNT | DATABASE [ <db_name> ] | [ SCHEMA ] [ <schema_name> ] } ]
                       [ STARTS WITH '<name_string>' ]
                       [ LIMIT <rows> [ FROM '<name_string>' ] ]
Copy

Paramètres

TERSE

Retourne seulement un sous-ensemble des colonnes de sortie :

  • created_on

  • name

  • kind (renommer la colonne type dans un ensemble complet de colonnes)

  • database_name

  • schema_name

  • tableOn (renommer la colonne table_name dans un ensemble complet de colonnes)

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 | [ DATABASE ] db_name | [ SCHEMA ] schema_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 ou le schéma actuel/spécifié, ou pour l’ensemble de votre compte :

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

  • Si DATABASE ou SCHEMA est spécifié sans nom et que la session n’a pas de base de données actuellement utilisée, le paramètre n’a aucun effet sur la sortie.

  • Si SCHEMA est spécifié avec un nom et que la session n’utilise pas de base de données, le nom du schéma doit être entièrement qualifié avec le nom de la base de données (par ex. testdb.testschema).

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

  • 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 flux et les métadonnées dans les colonnes suivantes :

Colonne

Description

created_on

Date et heure de création du flux.

name

Nom du flux.

database_name

Base de données pour le schéma du flux.

schema_name

Schéma du flux.

owner

Rôle qui possède le flux.

comment

Commentaire pour le flux.

table_name

Table dont les mises à jour DML sont suivies par le flux.

source_type

Objet source du flux : table, vue, table de répertoire ou table externe.

base_tables

Tables sous-jacentes de la vue. Cette colonne s’applique aux flux sur les vues uniquement.

type

Type du flux ; actuellement DELTA seulement.

stale

Indique si le flux a été lu pour la dernière fois avant l’heure stale_after (voir ci-dessous). Si cette valeur est TRUE, le flux peut être périmé. Lorsqu’un flux est périmé, il ne peut pas être lu. Recréez le flux pour en reprendre la lecture. Pour éviter qu’un flux ne devienne périmé, consommez le flux avant stale_after .

mode

Affiche APPEND_ONLY si le flux est un flux d’ajout uniquement. . Affiche INSERT_ONLY si le flux ne renvoie que des informations sur les lignes insérées ; s’applique actuellement aux flux sur des tables externes uniquement. . Pour les flux sur les tables, la colonne affiche DEFAULT.

stale_after

Horodatage lorsque le flux est devenu périmé ou peut le devenir s’il n’est pas consommé. . . La valeur est calculée en ajoutant la période de conservation de la table source (c’est-à-dire le plus grand des paramètres DATA_RETENTION_TIME_IN_DAYS ou MAX_DATA_EXTENSION_TIME_IN_DAYS) à la dernière lecture du flux. Si la période de conservation des données est définie au niveau du schéma ou de la base de données, le rôle actuel doit avoir accès au schéma ou à la base de données pour effectuer ce calcul. . . Cette durée peut être inexacte dans certains cas : . - Un certain temps peut s’écouler entre le moment où le flux est autorisé à devenir périmé et le moment où les données sous-jacentes sont effectivement supprimées. Pendant cette période, stale_after sera dans le passé, mais la lecture du flux peut réussir. La durée de cette période est susceptible d’être modifiée, vous ne devez donc pas vous y fier. . - Si les paramètres affectant la conservation des tables sont augmentés, les flux qui sont déjà périmés le resteront, mais le moment stale_after peut se situer dans le futur.

invalid_reason

Raison pour laquelle le flux ne peut pas être interrogé avec succès. Cette colonne prend en charge les fonctionnalités futures. Actuellement, la seule valeur renvoyée est N/A.

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.

Pour plus d’informations sur les propriétés qui peuvent être spécifiées pour un flux, voir CREATE STREAM.

Exemples

Afficher tous les flux dont le nom commence par line que vous avez les privilèges d’afficher dans le schéma tpch.public :

SHOW STREAMS LIKE 'line%' IN tpch.public;
Copy