SHOW ONLINE FEATURE TABLES¶
Liste les tables de fonctionnalités en ligne pour lesquelles vous disposez de privilèges d’accès.
Vous pouvez utiliser cette commande pour répertorier les objets de la base de données et du schéma actuels de la session, d’une base de données ou d’un schéma spécifique ou de l’ensemble de votre compte.
La sortie comprend les métadonnées et les propriétés de chaque objet. Les objets sont triés lexicographiquement par nom de base de données, de schéma et d’objet (voir Sortie dans cette rubrique pour la description des colonnes de sortie). L’ordre des lignes dans les résultats est important à noter si vous souhaitez filtrer les résultats.
- Voir aussi :
CREATE ONLINE FEATURE TABLE , ALTER ONLINE FEATURE TABLE, DESCRIBE ONLINE FEATURE TABLE , DROP ONLINE FEATURE TABLE
Syntaxe¶
SHOW ONLINE FEATURE TABLES [ LIKE '<pattern>' ]
[ IN
{
ACCOUNT |
DATABASE |
DATABASE <database_name> |
SCHEMA |
SCHEMA <schema_name> |
<schema_name>
}
]
[ STARTS WITH '<name_string>' ]
[ LIMIT <rows> [ FROM '<name_string>' ] ]
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 :
ACCOUNTRenvoie les enregistrements pour l’ensemble du compte.
DATABASE, .DATABASE db_nameRenvoie 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
DATABASEsansdb_nameet qu’aucune base de données n’est utilisée, le mot-clé n’a aucun effet sur la sortie.Note
L’utilisation de commandes SHOW sans clause
INdans un contexte de base de données peut donner moins de résultats que prévu.Les objets portant le même nom ne sont affichés qu’une seule fois si aucune clause
INn’est utilisée. Par exemple, si la tablet1se trouve dansschema1et la tablet1dansschema2et si elles sont toutes les deux dans le champ d’application du contexte de base de données que vous avez spécifié (c’est-à-dire, si la base de données que vous avez sélectionnée est le parent deschema1et deschema2), SHOW TABLES n’affiche qu’une seule des tablest1.SCHEMA, .SCHEMA schema_nameRenvoie les enregistrements pour le schéma en cours d’utilisation ou un schéma spécifié (
schema_name).SCHEMAest facultatif si une base de données est utilisée ou si vous spécifiez leschema_namecomplet (par exemple,db.schema).Si aucune base de données n’est utilisée, spécifier
SCHEMAn’a aucun effet sur la sortie.
Si vous omettez
IN ..., la portée de la commande dépend de l’existence ou non d’une base de données en cours d’utilisation dans la session :Une base de données est en cours d’utilisation, la commande renvoie les objets pour lesquels vous disposez de privilèges d’affichage dans la base de données. Cela a le même effet que de spécifier
IN DATABASE.Si aucune base de données n’est en cours d’utilisation, la commande renvoie les objets que vous pouvez visualiser dans votre compte. Cela a le même effet que de spécifier
IN ACCOUNT.
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'etSTARTS 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 parSTARTS 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).
Sortie¶
La sortie de la commande comprend les colonnes suivantes, qui décrivent les propriétés et les métadonnées de l’objet :
Colonne |
Description |
|---|---|
|
Heure de création de la table des fonctionnalités en ligne. |
|
Nom de la table des fonctionnalités en ligne. |
|
Base de données dans laquelle réside la table des fonctionnalités en ligne. |
|
Schéma dans lequel réside la table des fonctionnalités en ligne. |
|
Nombre de lignes du stockage. |
|
Nombre d’octets qui seront analysés si la table des fonctionnalités en ligne entière est analysée dans une requête. Notez que ce nombre peut être différent du nombre d’octets physiques réels stockés pour la table. |
|
Rôle qui possède la table des fonctionnalités en ligne. |
|
Nom de la source des données de la table des fonctionnalités en ligne. |
|
Durée maximale de retard du contenu de la table des fonctionnalités en ligne par rapport au temps réel. |
|
Entrepôt utilisé pour les actualisations des tables de fonctionnalités en ligne. |
|
Colonne d’horodatage spécifiée lors de la création de la table des fonctionnalités en ligne. |
|
|
|
Explication du choix du mode d’actualisation. Si Snowflake a sélectionné |
|
Affiche |
|
Commentaire pour la table des fonctionnalités en ligne. |
Note
Les nombres dans les colonnes rows et bytes peuvent ne pas être précis si les données changent fréquemment. Vous pouvez exécuter une requête SELECT COUNT(*) sur la table pour obtenir un nombre précis de lignes.
Exigences en matière de contrôle d’accès¶
Privilège |
Objet |
Remarques |
|---|---|---|
USAGE |
Schéma |
Rôle qui dispose du privilège USAGE sur le schéma. |
Pour obtenir des instructions sur la création d’un rôle personnalisé avec un ensemble spécifique de privilèges, voir Création de rôles personnalisés.
Pour des informations générales sur les rôles et les privilèges accordés pour effectuer des actions SQL sur des objets sécurisables, voir Aperçu du contrôle d’accès.
Notes sur l’utilisation¶
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 l’opérateur de canal (
->>) ou la fonction RESULT_SCAN. Les deux constructions traitent la sortie comme un jeu de résultats que vous pouvez interroger.Les noms des colonnes de sortie pour cette commande sont générés en minuscules. Si vous consommez un jeu de résultats de cette commande avec l’opérateur de canal ou la fonction RESULT_SCAN, utilisez des identificateurs entre guillemets doubles pour les noms de colonnes de la requête, afin de vous assurer qu’ils correspondent aux noms de colonnes dans la sortie analysée. Par exemple, si le nom d’une colonne de sortie est
type, spécifiez"type"pour l’identificateur.
La commande renvoie un maximum de dix mille enregistrements pour le type d’objet spécifié, conformément aux privilèges d’accès du rôle utilisé pour exécuter la commande. Aucun enregistrement au-delà de la limite de dix mille enregistrements n’est renvoyé, même si un filtre a été appliqué.
Pour afficher les résultats pour lesquels il existe plus de dix mille enregistrements, interrogez la vue correspondante (le cas échéant) dans Schéma d’information de Snowflake.
L’exécution de la commande pour les objets de niveau schéma ne renvoie un objet que si le rôle actuel dispose également d’au moins un privilège sur la base de données et le schéma de niveau parent.
Exemples¶
L’exemple suivant liste les tables de fonctionnalités en ligne que vous avez le privilège de voir dans le schéma PUBLIC de la base de données mydb :
USE DATABASE mydb;
SHOW ONLINE FEATURE TABLES;
L’exemple suivant liste toutes les tables de fonctionnalités en ligne du compte actuel qui commencent par feature_ :
SHOW ONLINE FEATURE TABLES STARTS WITH 'feature_' IN ACCOUNT;
L’exemple suivant répertorie les tables de fonctionnalités en ligne dont les noms correspondent au modèle %test% dans le schéma analytics :
SHOW ONLINE FEATURE TABLES LIKE '%test%' IN SCHEMA analytics;