SHOW MATERIALIZED VIEWS¶
Listet die materialisierten Ansichten auf, für die Sie Zugriffsrechte haben.
Weitere Informationen zu materialisierten Ansichten finden Sie unter Verwenden von materialisierten Ansichten.
- Siehe auch:
CREATE MATERIALIZED VIEW, ALTER MATERIALIZED VIEW, DROP MATERIALIZED VIEW, DESCRIBE MATERIALIZED VIEW
Syntax¶
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> |
}
]
Parameter¶
LIKE 'pattern'
Filtert optional die Befehlsausgabe nach dem Objektnamen. Der Filter verwendet einen Musterabgleich ohne Berücksichtigung der Groß-/Kleinschreibung, aber mit Unterstützung von SQL-Platzhalterzeichen (
%
und_
).Die folgenden Muster geben beispielsweise die gleichen Ergebnisse zurück:
... LIKE '%testing%' ...
... LIKE '%TESTING%' ...
. Standard: Kein Wert (die Ausgabe wird nicht gefiltert).
[ IN ... ]
Gibt optional den Geltungsbereich des Befehls an. Geben Sie eine der folgenden Optionen an:
ACCOUNT
Gibt Datensätze für das gesamte Konto zurück.
DATABASE
, .DATABASE db_name
Gibt Datensätze für die aktuell verwendete Datenbank oder eine angegebene Datenbank (
db_name
) zurück.Wenn Sie
DATABASE
ohnedb_name
angeben und aktuell keine Datenbank in Verwendung ist, hat das Schlüsselwort keine Auswirkungen auf die Ausgabe.Bemerkung
Die Verwendung von SHOW-Befehlen ohne eine
IN
-Klausel in einem Datenbankkontext kann zu weniger Ergebnissen als erwartet führen.Objekte mit demselben Namen werden nur einmal angezeigt, wenn keine
IN
-Klausel verwendet wird. Wenn Sie z. B. die Tabellet1
inschema1
und die Tabellet1
inschema2
haben und beide im Geltungsbereich des von Ihnen angegebenen Datenbankkontextes liegen (d. h. die von Ihnen ausgewählte Datenbank ist die übergeordnete Datenbank vonschema1
undschema2
), dann zeigt SHOW TABLES nur eine dert1
-Tabellen an.SCHEMA
, .SCHEMA schema_name
Gibt Datensätze für das aktuell verwendete Schema oder ein angegebenes Schema (
schema_name
) zurück.SCHEMA
ist optional, wenn aktuell eine Datenbank in Verwendung ist oder wenn Sie fürschema_name
den vollqualifizierten Schemanamen (z. B.db.schema
) angeben.Wenn aktuell keine Datenbank in Verwendung ist, hat die Angabe von
SCHEMA
keine Auswirkungen auf die Ausgabe.
APPLICATION application_name
, .APPLICATION PACKAGE application_package_name
Gibt Datensätze für die genannte Snowflake Native App oder das Anwendungspaket zurück.
Standard: Abhängig davon, ob für die Sitzung aktuell eine Datenbank in Verwendung ist:
Datenbank:
DATABASE
ist der Standardwert (d. h. der Befehl gibt die Objekte zurück, für die Sie Berechtigungen zum Anzeigen in der Datenbank haben).Keine Datenbank:
ACCOUNT
ist der Standardwert (d. h. der Befehl gibt die Objekte zurück, für die Sie Berechtigungen zum Anzeigen in Ihrem Konto haben).
Nutzungshinweise¶
Die Ausgabespalten ähneln den Ausgabespalten für SHOW TABLES, enthalten jedoch die folgenden zusätzlichen Spalten:
„refreshed_on“: Zeitpunkt der letzten DML-Operation auf der Basistabelle, die durch eine Aktualisierungsoperation verarbeitet wurde.
„compacted_on“: Zeitpunkt der letzten DML-Operation auf der Basistabelle, die von einer Komprimierungsoperation verarbeitet wurde.
behind_by: Wenn der Hintergrundprozess, der die materialisierte Ansicht mit Änderungen aus der Basistabelle aktualisiert, die materialisierte Ansicht noch nicht auf den neuesten Stand gebracht hat, wird in dieser Spalte angezeigt, wie viele Sekunden die materialisierte Ansicht ungefähr hinter der Basistabelle liegt. Doch selbst wenn sich zeigt, dass die materialisierte Ansicht nicht auf dem neuesten Stand ist, liefern alle Abfragen auf der materialisierten Ansicht immer noch aktuelle Ergebnisse (diese können nur etwas länger dauern, da zusätzliche Informationen aus der Basistabelle abgerufen werden).
Der Befehl SHOW VIEWS zeigt auch Informationen zu materialisierten Ansichten an.
Für die Ausführung des Befehls ist kein aktives Warehouse erforderlich.
Der Befehl gibt nur Objekte zurück, für die der aktuellen Rolle des aktuellen Benutzers mindestens ein Zugriffsrecht zugewiesen wurde.
Das Zugriffsrecht MANAGE GRANTS gibt seinem Eigentümer implizit die Möglichkeit, jedes Objekt im Konto anzuzeigen. Standardmäßig haben nur der Kontoadministrator (Benutzer mit der Rolle ACCOUNTADMIN) und der Systemadministrator (Benutzer mit der Rolle SECURITYADMIN) die Berechtigung MANAGE GRANTS.
Zur Weiterverarbeitung der Ausgabe dieses Befehls können Sie die Funktion RESULT_SCAN verwenden, die die Ausgabe wie eine abfragbare Tabelle behandelt. Sie können auch den Pipe-Operator verwenden, um die Ausgabe dieses Befehls abzufragen.
Der Befehl gibt maximal zehntausend Datensätze für den angegebenen Objekttyp zurück, entsprechend den Zugriffsrechten für die zur Ausführung des Befehls verwendete Rolle. Datensätze, die die Grenze von zehntausend Datensätzen überschreiten, werden nicht zurückgegeben, selbst wenn ein Filter angewendet wurde.
Um Ergebnisse anzuzeigen, für die mehr als zehntausend Datensätze existieren, fragen Sie die entsprechende Ansicht (sofern vorhanden) in Snowflake Information Schema ab.
Ausgabe¶
Die Befehlsausgabe enthält Eigenschaften und Metadaten der materialisierten Ansicht in den folgenden Spalten:
Spalte |
Beschreibung |
---|---|
created_on |
Der Zeitstempel, zu dem die materialisierte Ansicht erstellt wurde. |
name |
Der Name der materialisierten Ansicht. |
reserved |
Reserviert für zukünftige Verwendung. |
database_name |
Der Name der Datenbank, in der die materialisierte Ansicht vorhanden ist. |
schema_name |
Der Name des Schemas, in dem die materialisierte Ansicht vorhanden ist. |
cluster_by |
Informationen zu den Clustering-Spalten (wenn die materialisierte Ansicht geclustert ist). |
rows |
Die Anzahl der Zeilen in der materialisierten Ansicht. |
bytes |
Die Anzahl der Datenbytes in der materialisierten Ansicht. |
source_database_name |
Der Name der Datenbank, in der die Basistabelle der materialisierten Ansicht vorhanden ist. |
source_schema_name |
Der Name des Schemas, in dem die Basistabelle der materialisierten Ansicht vorhanden ist. |
source_table_name |
Der Name der Basistabelle der materialisierten Ansicht. |
refreshed_on |
Der Zeitstempel für den Zeitpunkt der letzten DML-Operation auf der Basistabelle, die durch eine Aktualisierungsoperation verarbeitet wurde. |
compacted_on |
Der Zeitstempel für den Zeitpunkt der letzten DML-Operation auf der Basistabelle, die durch eine Komprimierungsoperation verarbeitet wurde. |
owner |
Der Besitzer der materialisierten Ansicht. |
invalid |
„True“, wenn die materialisierte Ansicht derzeit ungültig ist (z. B. wenn die Basistabelle eine Spalte gelöscht hat, die von der Ansicht verwendet wurde), sonst „false“. |
invalid_reason |
Der Grund (falls vorhanden), warum die materialisierte Ansicht derzeit ungültig ist. |
behind_by |
Zeitspanne, mit der die Aktualisierungen der materialisierten Ansicht hinter den Aktualisierungen der Basistabelle zurückliegen. |
comment |
Optionaler Kommentar. |
text |
Der Text des Befehls, der diese materialisierte Ansicht erstellt hat (z. B. CREATE MATERIALIZED VIEW …). |
is_secure |
„True“, wenn die materialisierte Ansicht eine sichere Ansicht ist, sonst „false“. |
automatic_clustering |
„True“, wenn die Ansicht geclustert ist und die Clusterbildung automatisch erfolgt. |
owner_role_type |
Der Typ der Rolle, die Eigentümer des Objekts ist, zum Beispiel |
owner_role_type |
Der Typ der Rolle, die Eigentümer des Objekts ist, zum Beispiel |
Beispiele¶
Anzeigen aller materialisierten Ansichten:
SHOW MATERIALIZED VIEWS;
Nur materialisierte Ansichten mit Namen anzeigen, die dem angegebenen regulären Ausdruck entsprechen:
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; | | | | | +-------------------------------+------+----------+---------------+-------------+------------+------+-------+----------------------+--------------------+-------------------+-------------------------------+--------------+----------+---------+----------------+-----------+---------+--------------------------------------------+-----------+----------------------+-----------------+