SHOW DYNAMIC TABLES

Listet die dynamischen Tabellen auf, für die Sie Zugriffsrechte haben. Mit diesem Befehl können Sie dynamische Tabellen der aktuellen bzw. der angegebenen Datenbank oder des angegebenen Schemas oder alle Tabellen Ihres Kontos auflisten.

Siehe auch:

CREATE DYNAMIC TABLE, ALTER DYNAMIC TABLE, DESCRIBE DYNAMIC TABLE, DROP DYNAMIC TABLE

SHOW OBJECTS

TABLES-Ansicht (Information Schema)

Syntax

SHOW DYNAMIC TABLES [ LIKE '<pattern>' ]
                    [ IN
                      {
                           ACCOUNT              |

                           DATABASE             |
                           DATABASE <db_name>   |

                           SCHEMA               |
                           SCHEMA <schema_name> |
                           <schema_name>
                      }
                    ]
                    [ STARTS WITH '<name_string>' ]
                    [ LIMIT <rows> [ FROM '<name_string>' ] ]
Copy

Parameter

LIKE 'pattern'

Filtert die Befehlsausgabe nach dem Objektnamen. Der Filter verwendet eine Mustererkennung 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%' ...
[ 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 ohne db_name angeben und aktuell keine Datenbank in Verwendung ist, hat das Schlüsselwort keine Auswirkungen auf die Ausgabe.

SCHEMA, . SCHEMA schema_name, . 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ür schema_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.

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

STARTS WITH 'name_string'

Filtert die Befehlsausgabe optional anhand der Zeichen, die am Anfang des Objektnamens angezeigt werden. Die Zeichenfolge muss in einfache Anführungszeichen gesetzt werden, wobei die Groß-/Kleinschreibung beachtet werden muss. Zum Beispiel werden bei Folgendem unterschiedliche Ergebnisse zurückgegeben:

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

Standard: Kein Wert (die Ausgabe wird nicht gefiltert)

LIMIT rows [ FROM 'name_string' ]

Schränkt optional die maximale Anzahl der zurückgegebenen Zeilen ein und ermöglicht gleichzeitig die „Paginierung“ der Ergebnisse. Beachten Sie, dass die tatsächliche Anzahl der zurückgegebenen Zeilen möglicherweise unter dem angegebenen Grenzwert liegt (z. B. liegt die Anzahl der vorhandenen Objekte unter dem angegebenen Grenzwert).

Die optionale Unterklausel FROM 'name_string' dient als „Cursor“ für die Ergebnisse. Dies ermöglicht das Abrufen der angegebenen Anzahl von Zeilen nach der ersten Zeile, deren Objektname mit der angegebenen Zeichenfolge übereinstimmt:

  • Die Zeichenfolge muss in einfache Anführungszeichen gesetzt werden, wobei zwischen Groß-/Kleinschreibung unterschieden wird.

  • Die Zeichenfolge muss nicht den vollständigen Datenbanknamen enthalten. Partielle Namen werden unterstützt.

Standard: Kein Wert (die Ausgabe wird nicht begrenzt)

Bemerkung

FROM 'name_string' und STARTS WITH 'name_string' können in derselben Anweisung kombiniert werden. Beide Bedingungen müssen jedoch erfüllt sein, da sie sich sonst gegenseitig aufheben und keine Ergebnisse zurückgegeben werden.

Außerdem werden Objekte in lexikographischer Reihenfolge nach Namen zurückgegeben. Daher gibt FROM 'name_string' nur Zeilen mit einem höheren lexikografischen Wert zurück als die von STARTS WITH 'name_string' zurückgegebenen Zeilen.

Beispiel:

  • ... STARTS WITH 'A' LIMIT ... FROM 'B' würde keine Ergebnisse zurückgeben.

  • ... STARTS WITH 'B' LIMIT ... FROM 'A' würde keine Ergebnisse zurückgeben.

  • ... STARTS WITH 'A' LIMIT ... FROM 'AB' würde Ergebnisse zurückgeben (wenn Zeilen mit den Eingabezeichenfolgen übereinstimmen).

Nutzungshinweise

  • Um eine Tabelle mit SHOW zu beschreiben, müssen Sie eine Rolle verwenden, die über die MONITOR-Berechtigung für die Tabelle verfügt.

  • Für die Ausführung des Befehls ist kein aktives Warehouse erforderlich.

  • Der Wert für LIMIT rows kann 10000 nicht überschreiten. Wenn LIMIT rows nicht angegeben wird und das Resultset mehr als 10.000 Zeilen hat, führt der Befehl zu einem Fehler.

    Um Ergebnisse anzuzeigen, für die mehr als 10.000 Datensätze vorhanden sind, fügen Sie entweder LIMIT rows (Zeilen) ein, oder fragen Sie die entsprechende Ansicht im Snowflake Information Schema ab.

  • Zur Nachbearbeitung der Ausgabe dieses Befehls können Sie die Funktion RESULT_SCAN verwenden, die die Ausgabe wie eine abfragbare Tabelle behandelt.

Ausgabe

Die Befehlsausgabe enthält Tabelleneigenschaften und Metadaten in den folgenden Spalten:

Spalte

Beschreibung

created_on

Datum und Uhrzeit, zu denen die dynamische Tabelle erstellt wurde.

name

Name der dynamischen Tabelle.

reserved

database_name

Datenbank, in der die dynamische Tabelle gespeichert ist.

schema_name

Schema, in dem die dynamische Tabelle gespeichert ist.

cluster_by

rows

Anzahl der Zeilen in der Tabelle.

bytes

Anzahl der Bytes, die gescannt werden, wenn die gesamte Tabelle in einer Abfrage durchsucht wird. . . Beachten Sie, dass diese Anzahl von der Anzahl der tatsächlichen physischen Bytes (d. h. der auf der Festplatte gespeicherten Bytes) für die Tabelle abweichen kann.

owner

Rolle, die Eigentümer der dynamischen Tabelle ist.

target_lag

Die maximale Dauer, die der Inhalt der dynamischen Tabelle hinter der Echtzeit zurückbleiben soll.

refresh_mode

INCREMENTAL wenn die dynamische Tabelle inkrementelle Aktualisierungen verwendet, oder FULL, wenn die gesamte Tabelle bei jeder Aktualisierung neu berechnet werden soll.

refresh_mode_reason

Erläuterung, warum der Aktualisierungsmodus FULL gewählt wurde. NULL wenn der Aktualisierungsmodus nicht FULL ist.

warehouse

Warehouse, das die erforderlichen Ressourcen zum Ausführen der inkrementellen Aktualisierungen bereitstellt.

comment

Kommentar zur dynamischen Tabelle.

text

Der Text des Befehls, der diese materialisierte Ansicht erstellt hat (z. B. CREATE DYNAMIC TABLE ...).

automatic_clustering

Ob Auto-Clustering für die dynamische Tabelle aktiviert ist. Wird derzeit nicht für dynamische Tabellen unterstützt.

scheduling_state

Zeigt RUNNING für dynamische Tabellen, die aktiv Aktualisierungen planen, und SUSPENDED für angehaltene dynamische Tabellen an.

last_suspended_on

Zeitstempel des letzten Anhaltens.

is_clone

TRUE, wenn die dynamische Tabelle geklont wurde, sonst FALSE.

is_replica

TRUE, wenn die dynamische Tabelle ein Replikat ist, sonst FALSE.

data_timestamp

Zeitstempel der Daten in Basisobjekten, die in der dynamischen Tabelle enthalten sind.

Beispiele

Anzeigen aller dynamischen Tabellen, deren Namen im Schema mydb.myschema mit product_ beginnen:

SHOW DYNAMIC TABLES LIKE 'product_%' IN SCHEMA mydb.myschema;
Copy