SHOW MATERIALIZED VIEWS¶
Répertorie les vues matérialisées auxquelles vous avez le droit d’accéder.
Pour plus d’informations sur les vues matérialisées, voir Travailler avec des vues matérialisées.
- Voir aussi :
CREATE MATERIALIZED VIEW , ALTER MATERIALIZED VIEW , DROP MATERIALIZED VIEW , DESCRIBE MATERIALIZED VIEW
Syntaxe¶
SHOW MATERIALIZED VIEWS [ LIKE '<pattern>' ]
[ IN
{
ACCOUNT |
DATABASE |
DATABASE <database_name> |
SCHEMA |
SCHEMA <schema_name> |
<schema_name>
APPLICATION <application_name> |
APPLICATION PACKAGE <application_package_name> |
}
]
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 :
ACCOUNT
Renvoie les enregistrements pour l’ensemble du compte.
DATABASE
, .DATABASE db_name
Renvoie 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
DATABASE
sansdb_name
et 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
IN
dans 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
IN
n’est utilisée. Par exemple, si la tablet1
se trouve dansschema1
et la tablet1
dansschema2
et 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 deschema1
et deschema2
), SHOW TABLES n’affiche qu’une seule des tablest1
.SCHEMA
, .SCHEMA schema_name
Renvoie les enregistrements pour le schéma en cours d’utilisation ou un schéma spécifié (
schema_name
).SCHEMA
est facultatif si une base de données est utilisée ou si vous spécifiez leschema_name
complet (par exemple,db.schema
).Si aucune base de données n’est utilisée, spécifier
SCHEMA
n’a aucun effet sur la sortie.
APPLICATION application_name
, .APPLICATION PACKAGE application_package_name
Renvoie les enregistrements pour l”Snowflake Native App nommée ou un paquet d’application.
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).
Notes sur l’utilisation¶
Les colonnes de sortie sont similaires aux colonnes de sortie pour SHOW TABLES, mais incluent les colonnes supplémentaires suivantes :
refreshed_on : heure de la dernière opération DML sur la table de base qui a été traitée par une opération d”« actualisation ».
compacted_on : heure de la dernière opération DML sur la table de base qui a été traitée par une opération de « compactage ».
behind_by : si le processus d’arrière-plan qui met à jour la vue matérialisée avec les modifications apportées à la table de base n’a pas encore mis à jour la vue matérialisée, cette colonne indique le nombre de secondes environ pendant lequel la vue matérialisée est « derrière » la table de base. Notez que même si cela indique que la vue matérialisée n’est pas à jour, toutes les requêtes sur la vue matérialisée renverront toujours des résultats actualisés (elles risquent simplement de prendre un peu plus de temps si des informations supplémentaires sont extraites de la table de base).
La commande SHOW VIEWS affiche également des informations sur les vues matérialisées.
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 la fonction RESULT_SCAN qui traite la sortie sous forme de table à interroger. Vous pouvez également utiliser l”opérateur de canal pour interroger la sortie de cette commande.
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.
Sortie¶
La sortie de commande fournit les propriétés des vues matérialisées et les métadonnées dans les colonnes suivantes :
Colonne |
Description |
---|---|
created_on |
Horodatage auquel la vue matérialisée a été créée. |
name |
Nom de la vue matérialisée. |
reserved |
Réservé pour une utilisation future. |
database_name |
Nom de la base de données dans laquelle la vue matérialisée existe. |
schema_name |
Nom du schéma dans lequel la vue matérialisée existe. |
cluster_by |
Informations sur les colonnes de clustering (si la vue matérialisée est clusterisée). |
rows |
Nombre de lignes dans la vue matérialisée. |
bytes |
Nombre d’octets de données dans la vue matérialisée. |
source_database_name |
Nom de la base de données dans laquelle la table de base de la vue matérialisée existe. |
source_schema_name |
Nom du schéma dans lequel la table de base de la vue matérialisée existe. |
source_table_name |
Nom de la table de base de la vue matérialisée. |
refreshed_on |
Horodatage de la dernière opération DML sur la table de base qui a été traitée par une opération d”« actualisation ». |
compacted_on |
Horodatage de la dernière opération DML sur la table de base qui a été traitée par une opération de « compactage ». |
owner |
Propriétaire de la vue matérialisée. |
invalid |
True si la vue matérialisée n’est pas valide actuellement (par exemple, si la table de base a supprimé une colonne utilisée par la vue) ; false dans les autres cas. |
invalid_reason |
La raison (le cas échéant) pour laquelle la vue matérialisée n’est pas valide actuellement. |
behind_by |
Dans quelle mesure les mises à jour de la vue matérialisée sont antérieures à celles de la table de base. |
comment |
Commentaire facultatif. |
text |
Le texte de la commande qui a créé cette vue matérialisée (par exemple, CREATE MATERIALIZED VIEW …). |
is_secure |
True si la vue matérialisée est une vue sécurisée ; false dans les autres. |
automatic_clustering |
True si la vue est mise en cluster et que le clustering est automatique. |
owner_role_type |
Type de rôle qui possède l’objet, par exemple |
owner_role_type |
Type de rôle qui possède l’objet, par exemple |
Exemples¶
Afficher toutes les vues matérialisées :
SHOW MATERIALIZED VIEWS;
Afficher uniquement les vues matérialisées dont le nom correspond à l’expression régulière spécifiée :
SHOW MATERIALIZED VIEWS LIKE 'mv1%'; +-------------------------------+------+----------+---------------+-------------+------------+------+-------+----------------------+--------------------+-------------------+-------------------------------+--------------+----------+---------+----------------+-----------+---------+--------------------------------------------+-----------+----------------------+-----------------+ | created_on | name | reserved | database_name | schema_name | cluster_by | rows | bytes | source_database_name | source_schema_name | source_table_name | refreshed_on | compacted_on | owner | invalid | invalid_reason | behind_by | comment | text | is_secure | automatic_clustering | owner_role_type | |-------------------------------+------+----------+---------------+-------------+------------+------+-------+----------------------+--------------------+-------------------+-------------------------------+--------------+----------+---------+----------------+-----------+---------+--------------------------------------------+-----------|----------------------+-----------------| | 2018-10-05 17:13:17.579 -0700 | MV1 | | TEST_DB1 | PUBLIC | | 0 | 0 | TEST_DB1 | PUBLIC | INVENTORY | 2018-10-05 17:13:50.373 -0700 | NULL | SYSADMIN | false | NULL | 0s | | CREATE OR REPLACE MATERIALIZED VIEW mv1 AS | false | OFF | ROLE | | | | | | | | | | | | | | | | | | | | SELECT ID, price FROM inventory; | | | | | +-------------------------------+------+----------+---------------+-------------+------------+------+-------+----------------------+--------------------+-------------------+-------------------------------+--------------+----------+---------+----------------+-----------+---------+--------------------------------------------+-----------+----------------------+-----------------+