Catégories :

Table, vue et séquence DDL

SHOW VIEWS

Liste les vues, y compris les vues sécurisées, pour lesquelles vous avez des privilèges d’accès. La commande peut être utilisée pour lister les vues 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 de la vue, classées lexicographiquement par nom de base de données, de schéma et de vue. Ceci est important à noter si vous souhaitez filtrer les résultats à l’aide des filtres fournis.

Voir aussi :

ALTER VIEW , CREATE VIEW , DROP VIEW

Vue VIEWS (Schéma d’information)

Syntaxe

SHOW [ TERSE ] VIEWS [ 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

  • database_name

  • schema_name

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

LIKE 'motif'

(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 ] nom_bd | [ SCHEMA ] nom_schéma

(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 :

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 'chaîne_nom'

(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, ceci renvoie des résultats différents :

... STARTS WITH 'B' ...
... STARTS WITH 'b' ...

Par défaut : aucune valeur (aucun filtrage n’est appliqué à la sortie)

LIMIT lignes [ FROM 'chaîne_nom' ]

(Facultatif) Limite le nombre maximum de lignes retournées, tout en permettant la « pagination » des résultats. Notez que le nombre réel de lignes retournées pourrait ê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 'chaîne_nom' 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

Les deux FROM 'chaîne_nom' et STARTS WITH 'chaîne_nom' peuvent être combinés dans la même instruction ; cependant, les deux conditions doivent être remplies ou elles s’annulent mutuellement et aucun résultat n’est retourné.

De plus, les objets sont retournés dans l’ordre lexicographique par nom, donc FROM 'chaîne_nom' ne retourne que les lignes ayant une valeur lexicographique plus élevée que les lignes retournées par STARTS WITH 'chaîne_nom'.

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 virtuel en cours d’exécution.

  • La valeur pour LIMIT lignes ne peut pas dépasser 10000. Si LIMIT lignes 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 lignes ou interrogez la vue correspondante dans Schéma d’information.

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

  • De par sa conception, la commande de sortie inclut des vues sécurisées, mais ne fournit pas certaines informations sur ces vues à moins que vous n’utilisiez le rôle qui a la propriété de la vue. Pour afficher les détails des vues sécurisées, vous devez utiliser le rôle qui possède la vue ou utiliser la vue VIEWS dans Information Schema.

Sortie

La sortie de commande fournit les propriétés des colonnes et les métadonnées dans les colonnes suivantes :

Colonne

Description

created_on

Horodatage auquel la vue a été créée.

name

Nom de la vue.

reserved

(Réservé pour une utilisation future.)

database_name

Nom de la base de données dans laquelle réside la vue.

schema_name

Nom du schéma dans lequel réside la vue.

owner

Propriétaire de la vue.

comment

Commentaire facultatif.

text

Texte de la commande qui a créé la vue (par exemple CREATE VIEW ...).

is_secure

True si la vue est une vue sécurisée ; false dans les autres cas.

is_materialized

True si la vue est une vue matérialisée ; false dans les autres cas.

Exemples

Afficher toutes les vues dont le nom commence par line que vous avez le privilège de voir dans le schéma mydb.public :

SHOW VIEWS LIKE 'line%' IN mydb.public;

+-------------------------------+---------+----------+---------------+-------------+--------+---------+-------------------------------------------------------+-----------+-----------------+
| created_on                    | name    | reserved | database_name | schema_name | owner  | comment | text                                                  | is_secure | is_materialized |
+-------------------------------+---------+----------+---------------+-------------+--------+---------+-------------------------------------------------------+-----------+-----------------+
| 2019-05-24 18:41:14.247 -0700 | liners1 |          | MYDB          | PUBLIC      | TSMITH |         | create materialized views liners1 as select * from t; | false     | false           |
+-------------------------------+---------+----------+---------------+-------------+--------+---------+-------------------------------------------------------+-----------+-----------------+