SHOW ICEBERG TABLES

Répertorie les tables 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 [ <db_name> ] | SCHEMA [ <schema_name> ] } ]
                                  [ STARTS WITH '<name_string>' ]
                                  [ LIMIT <rows> [ FROM '<name_string>' ] ]
Copy

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 ICEBERG TABLE.

  • database_name

  • schema_name

Par défaut : aucune valeur (toutes les colonnes sont incluses dans la sortie)

ICEBERG

Renvoie 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  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' 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).

Exigences en matière de contrôle d’accès

Un rôle utilisé pour exécuter cette commande SQL doit avoir les privilèges suivants définis au minimum ainsi :

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.

Notez que l’exploitation d’un objet dans un schéma requiert également le privilège USAGE sur la base de données et le schéma parents.

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.

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

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

created_on

Date et heure de création de la table.

name

Nom de la table.

database_name

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

schema_name

Schéma dans lequel la table est stockée.

owner

Rôle qui possède la table.

external_volume_name

Nom du volume externe dans lequel sont stockées les données et métadonnées de la table Iceberg.

catalog_name

Nom de l’objet d’intégration de catalogue associé à la table Iceberg lorsque la table n’est pas gérée par Snowflake. SNOWFLAKE lorsque la table est gérée par Snowflake.

iceberg_table_type

Type de table Iceberg. UNMANAGED si la table n’est pas gérée par Snowflake. Sinon, NOT ICEBERG.

catalog_table_name

Nom de la table tel qu’il est reconnu par le catalogue.

catalog_namespace

Espace de noms du catalogue de la table. L’espace de noms défini lors de la création de la table. Sinon, l’espace de noms par défaut associé à l’intégration de catalogue utilisée par la table.

file_path

Chemin d’accès relatif à partir de l’emplacement EXTERNAL_VOLUME vers les métadonnées et fichiers de données de la table. Défini comme BASE_LOCATION lorsque vous créez certains types de tables Iceberg.

can_write_metadata

Indique si Snowflake peut écrire des métadonnées à l’emplacement spécifié par le file_path.

comment

Commentaire pour la table.

name_mapping

Liste d’objets contenant des informations sur les colonnes de table qui utilisent la projection de colonne. Pour plus d’informations, voir mappage_des_noms.

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.

mappage_des_noms

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"
        ]
      }
    ]
  }
]
Copy

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

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;
Copy

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

est_iceberg

Y si la table est une table Iceberg ; sinon, N.