SHOW HYBRID TABLES¶
Répertorie les tables hybrides pour lesquelles vous avez des privilèges d’accès.
La commande peut être utilisée pour répertorier les tables hybrides de la base de données ou du schéma actuel/spécifié ou pour l’ensemble de votre compte.
Cette commande renvoie des colonnes de sortie différentes de SHOW TABLES.
La sortie renvoie les métadonnées et les propriétés de la table hybride, classées lexicographiquement par nom de base de données, de schéma et de la table hybride (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.
Notez que cette rubrique fait référence aux tables Iceberg en les appelant simplement « tables », sauf lorsque le fait de préciser tables Iceberg permet d’éviter toute confusion.
- Voir aussi :
CREATE INDEX, DROP INDEX , SHOW INDEXES , CREATE HYBRID TABLE , DROP TABLE , DESCRIBE TABLE
Syntaxe¶
SHOW [ TERSE ] [ HYBRID ] TABLES [ LIKE '<pattern>' ]
[ IN { ACCOUNT | DATABASE [ <db_name> ] | SCHEMA [ <schema_name> ] } ]
[ STARTS WITH '<name_string>' ]
[ LIMIT <rows> [ FROM '<name_string>' ] ]
Paramètres¶
TERSE
(Facultatif) Retourne seulement un sous-ensemble des colonnes de sortie :
created_on
name
kind
La valeur de la colonne
kind
est toujours HYBRID TABLE.database_name
schema_name
Par défaut : aucune valeur (toutes les colonnes sont incluses dans la sortie)
HYBRID
Renvoie uniquement des tables hybrides.
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 ]
(Facultatif) 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.
Si vous spécifiez le mot clé
ACCOUNT
, la commande récupère les enregistrements de tous les schémas de toutes les bases de données du compte courant.Si vous spécifiez le mot clé
DATABASE
, alors :Si vous spécifiez un
db_name
, la commande récupère les enregistrements de tous les schémas de la base de données spécifiée.Si vous ne spécifiez pas un
db_name
, alors :S’il existe une base de données actuelle, la commande récupère les enregistrements de tous les schémas de la base de données actuelle.
S’il n’y a pas de base de données actuelle, la commande récupère les enregistrements de toutes les bases de données et de tous les schémas du compte.
Si vous spécifiez le mot clé
SCHEMA
, alors :Si vous spécifiez un nom de schéma qualifié (par exemple
my_database.my_schema
), la commande récupère les enregistrements de la base de données et du schéma spécifiés.Si vous spécifiez un
schema_name
non qualifié, alors :S’il existe une base de données actuelle, la commande récupère les enregistrements du schéma spécifié dans la base de données actuelle.
S’il n’y a pas de base de données actuelle, la commande affiche l’erreur
SQL compilation error: Object does not exist, or operation cannot be performed
.
Si vous ne spécifiez pas un
schema_name
, alors :S’il existe une base de données actuelle, alors :
S’il existe un schéma actuel, la commande récupère les enregistrements pour le schéma actuel dans la base de données actuelle.
S’il n’y a pas de schéma actuel, la commande récupère les enregistrements de tous les schémas de la base de données actuelle.
S’il n’y a pas de base de données actuelle, la commande récupère les enregistrements de toutes les bases de données et de tous les schémas du compte.
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. La commande renvoie les objets que vous avez le privilège d’afficher dans la base de données actuelle.Pas de base de données :
ACCOUNT
est la valeur par défaut. La commande renvoie les objets que vous avez le privilège d’afficher 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'
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).
Notes sur l’utilisation¶
Si un compte (ou une base de données ou un schéma) comporte un grand nombre de tables hybrides, la recherche dans l’ensemble du compte (ou de la base de données ou du schéma) peut consommer une quantité importante de ressources de calcul.
L’exécution de la commande ne nécessite pas un entrepôt virtuel en cours d’exécution.
La valeur pour
LIMIT rows
ne peut pas dépasser10000
. SiLIMIT 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¶
Note
Le schéma de sortie suivant correspond à la commande SHOW HYBRID TABLES. Pour des informations sur la sortie de SHOW TABLES, voir Identification des tables hybrides avec SHOW TABLES (dans cette rubrique).
La sortie de commande fournit les propriétés des tables et les métadonnées dans les colonnes suivantes :
Colonne |
Description |
---|---|
|
Date et heure de création de la table. |
|
Nom de la table. |
|
Base de données dans laquelle la table est stockée. |
|
Schéma dans lequel la table est stockée. |
|
Rôle qui possède la table. |
|
Nombre de lignes de la table. |
|
Nombre d’octets qui seront analysés si la table 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. |
|
Commentaire pour la table. |
|
Type de rôle qui possède l’objet, soit |
Note
Les chiffres des colonnes rows
et bytes
peuvent ne pas apparaître exacts si les données changent constamment. Par exemple, un tel changement peut avoir lieu si de nouvelles données sont insérées en permanence dans la table hybride.
Exemples¶
Afficher toutes les tables hybrides dont le nom commence par product_
que vous avez les privilèges d’afficher dans le schéma mydb.myschema
:
SHOW HYBRID TABLES LIKE 'product_%' IN mydb.myschema;
Identification des tables hybrides avec SHOW TABLES¶
La sortie de la commande SHOW TABLES comporte une colonne qui indique si une table est une table hybride.
Cette colonne apparaît en plus des colonnes de sortie SHOW TABLES standards.
La colonne a le nom et les valeurs possibles suivants :
Nom de la colonne |
Valeurs |
---|---|
is_hybrid |
|