SHOW ICEBERG TABLES¶
Liste les Tables Apache Iceberg™ pour lesquelles vous avez des privilèges d’accès.
La commande peut être utilisée pour répertorier les tables Iceberg 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 Iceberg, classées lexicographiquement par nom de base de données, de schéma et de table Iceberg (voir Sortie dans cette rubrique 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 ICEBERG TABLE , DROP ICEBERG TABLE , DESCRIBE ICEBERG TABLE , ALTER ICEBERG TABLE , SHOW TABLES
Syntaxe¶
SHOW [ TERSE ] [ ICEBERG ] 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¶
TERSE(Facultatif) Retourne seulement un sous-ensemble des colonnes de sortie :
created_onnamekindLa valeur de la colonne
kindest toujours ICEBERG TABLE.database_nameschema_name
Par défaut : aucune valeur (toutes les colonnes sont incluses dans la sortie)
ICEBERGRenvoie uniquement des tables Iceberg.
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 :If a database is currently in use, the command returns the objects you have privileges to view in the database. This has the same effect as specifying
IN DATABASE.If no database is currently in use, the command returns the objects you have privileges to view in your account. This has the same effect as specifying
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).
Exigences en matière de contrôle d’accès¶
Un rôle utilisé pour exécuter cette opération doit au minimum disposer des privilèges suivants :
Privilège |
Objet |
Remarques |
|---|---|---|
SELECT |
Table Iceberg |
Pour voir une table Iceberg en particulier dans la sortie de SHOW ICEBERG TABLES, un rôle doit avoir le privilège SELECT sur cette table. |
Le privilège USAGE relatif à la base de données et au schéma parents est exigé pour effectuer des opérations sur tout objet d’un schéma. Notez qu’un rôle doté d’un privilège quelconque sur un schéma permet à ce rôle de résoudre le schéma. Par exemple, un rôle doté du privilège CREATE sur un schéma peut créer des objets sur ce schéma sans également avoir le privilège USAGE attribué sur ce 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¶
Si un compte (ou une base de données ou un schéma) comporte un grand nombre de tables Iceberg, 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.
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.For example, you can use the pipe operator or RESULT_SCAN function to select specific columns from the SHOW command output or filter the rows.
When you refer to the output columns, use double-quoted identifiers for the column names. For example, to select the output column
type, specifySELECT "type".You must use double-quoted identifiers because the output column names for SHOW commands are in lowercase. The double quotes ensure that the column names in the SELECT list or WHERE clause match the column names in the SHOW command output that was scanned.
La valeur de
LIMIT rowsne peut pas dépasser10000. SiLIMIT rowsest 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 rowsou interroger la vue correspondante dans Schéma d’information de Snowflake.
Sortie¶
Note
Le schéma de sortie suivant correspond à la commande SHOW ICEBERG TABLES. Pour des informations sur la sortie de SHOW TABLES, voir Identification des tables Iceberg 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. |
|
Nom du volume externe dans lequel sont stockées les données et métadonnées de la table Iceberg. |
|
Nom de l’objet d’intégration de catalogue associé à la table Iceberg lorsque la table n’est pas gérée par Snowflake. |
|
Type de table Iceberg. |
|
Nom de la table tel qu’il est reconnu par le catalogue. |
|
Pour les tables gérées en externe, espace de noms défini lors de la création de la table. S’il n’est pas défini au niveau de la table, espace de noms par défaut associé à l’intégration de catalogue utilisée par la table. Pour les tables gérées par Snowflake que vous synchronisez avec Snowflake Open Catalog, ce champ n’est pas obligatoire ; la valeur est donc |
|
Chemin d’accès relatif à partir de l’emplacement |
|
Indique si Snowflake peut écrire des métadonnées à l’emplacement spécifié par le |
|
Commentaire pour la table. |
|
Liste d’objets contenant des informations sur les colonnes de table qui utilisent la projection de colonne. Pour plus d’informations, voir name_mapping. |
|
Type de rôle qui possède l’objet, par exemple |
|
Indique le nom de l’intégration de catalogue pour Snowflake Open Catalog auquel la table Apache Iceberg™ gérée par Snowflake se synchronise. Si la table ne se synchronise pas avec Snowflake Open Catalog ou n’est pas gérée par Snowflake, la valeur est |
|
Statut d’actualisation automatisé d’une table Iceberg gérée en externe. Cette colonne affiche les mêmes résultats pour la table que la fonction SYSTEM$AUTO_REFRESH_STATUS. |
|
Liste d’objets décrivant les spécifications de partition Apache Iceberg™ de la table, tels que trouvés dans le fichier de métadonnées Iceberg. Inclut la spécification pour les tables Iceberg gérées par Snowflake et celles gérées en externe. Pour plus d’informations, voir partition_specs. |
|
ID pour la spécification de partition qui est actuellement active pour la table Iceberg. Cet ID correspond à une valeur pour |
name_mapping¶
La colonne de sortie name_mapping fournit des informations sur les colonnes de table qui utilisent la projection de colonne.
Si une table ne contient aucune colonne avec un mappage de noms associé, la colonne de sortie a une valeur [NULL]. Sinon, la valeur est une liste d’objets, dans laquelle chaque objet correspond à une colonne à laquelle est associé un mappage de noms (parfois appelé champ mappé). Chaque objet peut contenir les trois propriétés suivantes :
field-id: L’ID du champ Iceberg.names: Une liste de chaînes de noms pour le champ.fields: Une liste de mappages de champs pour les champs enfants des colonnes struct, map ou list.
Par exemple :
[
{
"field-id": 1,
"names": [
"id",
"record_id"
]
},
{
"field-id": 2,
"names": [
"data"
]
},
{
"field-id": 3,
"names": [
"location"
],
"fields": [
{
"field-id": 4,
"names": [
"latitude",
"lat"
]
},
{
"field-id": 5,
"names": [
"longitude",
"long"
]
}
]
}
]
Note
Il se peut que les IDs de champ ne se suivent pas si une colonne ou un champ dans une colonne de type structuré n’a pas de mappage de nom associé.
partition_specs¶
Chaque objet dans la colonne partition_specs comprend un spec-id, suivi des champs de la spécification de partition. Chaque champ est une valeur OBJECT avec les paires clé-valeur suivantes :
name: Nom de la partition.transform: La transformation appliquée à la colonne source pour générer une valeur de partition. Cette valeur détermine comment les données sont regroupées en partitions.source-id: L’identificateur de la colonne de table d’origine ou du champ utilisé pour le partitionnement.field-id: L’ID du champ de partition. Ce champ identifie un champ de partition et est unique dans une spécification de partition. Toutefois, pour les métadonnées de table Iceberg V2, le champ ID est unique pour toutes les spécifications de partition.
Par exemple :
[ {
"spec-id" : 0,
"fields" : [ {
"name" : "COL1",
"transform" : "identity",
"source-id" : 1,
"field-id" : 1000
}, {
"name" : "COL1_trunc_100",
"transform" : "truncate[100]",
"source-id" : 1,
"field-id" : 1001
}
]
} ]
L’exemple montre une spécification de partition ; cependant, une table peut avoir plusieurs spécifications de partition.
Exemples¶
Afficher toutes les tables Iceberg dont le nom commence par glue pour lesquelles vous disposez du privilège d’affichage dans le schéma tpch.public :
SHOW ICEBERG TABLES LIKE 'glue%' IN tpch.public;
Identification des tables Iceberg avec SHOW TABLES¶
La sortie de la commande SHOW TABLES comporte une colonne qui indique si une table est une table Iceberg. 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_iceberg |
|