Snowflake
In diesem Artikel werden das Herstellen einer Verbindung zwischen Tableau und einem Snowflake Data Warehouse und das Einrichten der Datenquelle beschrieben.
Voraussetzungen
Stellen Sie zunächst diese Verbindungsinformationen zusammen:
- Name des Servers, zu dem Sie eine Verbindung herstellen möchten
- Authentifizierungsmethode:
- OAuth: Verwenden Sie diese Methode, wenn Sie den Verbund von einem Identitätsanbieter aus aktivieren möchten.
- SAML IDP: Verwenden Sie diese Methode, wenn Sie die IDP-Anmeldeinformationen in die Verbindung einbetten möchten.
- Benutzername und Kennwort: Verwenden Sie diese Methode, wenn Sie Benutzeranmeldeinformationen in Snowflake speichern möchten.
- Die Anmeldedaten hängen von der gewählten Authentifizierungsmethode ab
- (Optional) SQL-Anfangsdatenanweisung, die bei jeder Verbindungsherstellung von Tableau ausgeführt wird
Treiber erforderlich
Damit dieser Connector mit der Datenbank kommunizieren kann, wird ein Treiber benötigt. Wenn der Treiber nicht auf Ihrem Computer installiert ist, wird in Tableau eine Meldung im Verbindungsdialogfeld angezeigt, die einen Link zu der Seite Treiber herunterladen(Link wird in neuem Fenster geöffnet) enthält. Dort finden Sie Treiber-Links und Installationsanweisungen.
Hinweis: Um die Verwendung von OAuth mit Snowflake zu unterstützen, müssen Sie einen ODBC-Treiber von Snowflake mit der Version 2.25.4 oder neuer installieren.
Herstellen der Verbindung und Einrichten der Datenquelle
Nachdem Sie Snowflake als Ihre Verbindung ausgewählt haben, wird ein POPUP-Menü mit 3 Registerkarten angezeigt. Verwenden Sie die Registerkarte Allgemein für die Authentifizierung. Sie können auch die SQL-Anfangsdaten auswählen, wenn Sie einen SQL-Befehl am Anfang jeder Verbindung ausführen möchten. Weitere Informationen finden Sie unter Ausführen von initialen SQL-Befehlen. Sie können die Registerkarte Erweitert verwenden, um Kundenverbindungen mit Parametern hinzuzufügen.
Tableau mit Ihren Daten verbinden
- Starten Sie Tableau, und wählen Sie unter Verbinden die Option Snowflake aus.
- Geben Sie den Namen des Servers ein, zu dem Sie eine Verbindung herstellen möchten.
- Wählen Sie die Methode für die Authentifizierung aus: Benutzername und Kennwort, Okta-Benutzername und -Kennwort oder Mit OAuth anmelden.
- Wählen Sie eine der Authentifizierungsmethoden aus und führen Sie die Anmeldeschritte aus.
Okta-Benutzername und -Kennwort:
- Geben Sie den Benutzernamen und das Kennwort ein,
- Geben Sie im Feld Okta die URL für den Okta-Server ein.
Mit OAuth anmelden
- (optional) Wählen Sie SQL-Anfangsdaten aus, wenn Sie einen SQL-Befehl am Anfang jeder Verbindung ausführen möchten. Weitere Informationen finden Sie unter Ausführen von initialen SQL-Befehlen.
- Wählen Sie Anmelden aus.
- Melden Sie sich auf der geöffneten Webseite bei Snowflake an, indem Sie Ihren Benutzernamen und Ihr Kennwort eingeben und Anmelden auswählen. Oder wählen Sie Single Sign-On aus, wenn Snowflake für die Unterstützung von SSO konfiguriert ist.
- Klicken Sie auf OK , um die Autorisierung für den Zugriff auf Ihre Snowflake-Daten zu bestätigen.
- Schließen Sie das Browserfenster und Tableau.
- Fahren Sie mit dem nächsten Abschnitt "Einrichten der Datenquelle" fort.
- Wählen Sie Anmelden aus.
Wenn Tableau keine Verbindung herstellen kann, überprüfen Sie die Richtigkeit Ihrer Anmeldeinformationen. Falls Sie weiterhin keine Verbindung herstellen können, kann der Computer den Server nicht finden. Wenden Sie sich an Ihren Netzwerkadministrator oder Datenbankadministrator.
Timeout des Zugriffstokens: Zugriffstoken-TDC immer validieren
Der Snowflake-Zugriffstoken läuft nach 10 Minuten ab. Bei bestimmten Extrakt-Aktualisierungsprozessen werden zu einem späteren Zeitpunkt im Auftrag neue Verbindungen hergestellt, wenn der Zugriffstoken abgelaufen ist. Um dieses Problem zu beheben, haben wir eine neue Funktion hinzugefügt, die ab Tableau 2024.2 standardmäßig aktiviert ist. Um diese Funktion in älteren Versionen zu aktivieren, können Sie den folgenden TDC-Datei verwenden.
<connection-customization class='snowflake' enabled='true' version='10.0'>
<vendor name='snowflake' />
<driver name='snowflake' />
<customizations>
<customization name='CAP_OAUTH_VALIDATE_ALWAYS' value='yes'/>
</customizations>
</connection-customization>
Wenn Sie Tableau Cloud verwenden, können Sie Veröffentlichungen über Tableau Desktop durchführen, wenn die TDC-Datei im Datenquellenordner des Tableau-Repositorys installiert ist. Dadurch wird die TDC-Datei beim Veröffentlichen in die Arbeitsmappe oder Datenquelle eingebettet.
Die eingebettete TDC-Datei wird immer angewendet, unabhängig vom Status des aktivierten Flags, solange auf der Serverseite keine andere TDC-Datei installiert ist. Auf Tableau Cloud ist nie eine TDC-Datei installiert (nur eingebettet).
Hinweis: Eingebettete TDC-Dateien werden mit Schemata nicht unterstützt.
Anpassen der Verbindung mithilfe von Treiberparametern
Sie können die mit dem Snowflake-Connector vorgenommene Verbindung ändern, indem Sie in der Registerkarte Erweitert Treiberparameter an die Verbindungszeichenfolge anhängen.
Hinweis: Sie können die von Tableau generierten Treiberparameter nicht ändern; Sie können lediglich die Parameter anhängen.
Diese Syntax gibt beispielsweise einen Proxyserver an, der verwendet werden soll, wenn die no_proxy
-Werte nicht erfüllt sind und Hostnamen den Proxyserver umgehen dürfen:
Proxy=http://proxyserver.company:80;no_proxy=.trustedserver.com;
Ein weiteres Beispiel für benutzerdefinierte Treiberparameter finden Sie unter Verwenden eines Proxys für Snowflake.
Hinweis: Wenn Sie Anpassungen wünschen, ohne sie in die Datenquelle einzubetten, können Sie unter Windows Parameter in der Registrierung konfigurieren (nur Parameter, die als "Konfigurationsparameter" gekennzeichnet sind, sind verfügbar). Einzelheiten zu Treiberparametern finden Sie unter ODBC-Konfigurations- und Verbindungsparameter auf der Snowflake-Website.
Einrichten der Datenquelle
Gehen Sie auf der Datenquellenseite wie folgt vor:
(Optional) Wählen Sie den Standard-Datenquellennamen oben auf der Seite aus, und geben Sie dann einen eindeutigen Datenquellennamen für die Verwendung in Tableau ein. Beispielsweise können Sie eine Benennungskonvention für die Datenquelle verwenden, die anderen Benutzern hilft, daraus abzuleiten, welche Datenquelle verbunden werden soll.
- Wählen Sie in der Dropdown-Liste Warehouse ein Warehouse aus, oder suchen Sie im Textfeld anhand des Namens nach einem Warehouse.
Hinweis: Wenn Sie dieses Feld leer lassen und kein Warehouse auswählen, verwendet Tableau Ihr virtuelles Warehouse in Snowflake.
Weitere Informationen finden Sie unter Standardmäßige virtuelle Warehouses in Snowflake.
- Wählen Sie in der Dropdown-Liste Datenbank eine Datenbank aus, oder suchen Sie mithilfe des Textfeldes nach einer Datenbank anhand ihres Namens.
- Wählen Sie in der Dropdown-Liste Schema ein Schema aus, oder suchen Sie mithilfe des Textfeldes ein Schema anhand seines Namens.
- Wählen Sie unter Tabelle eine Tabelle aus, oder suchen Sie über das Textfeld eine Tabelle nach Namen.
Ziehen Sie die Tabelle in den Arbeitsbereich, und klicken Sie dann auf die Blattregisterkarte, um Ihre Analyse zu starten.
Anmelden bei einem Mac
Wenn Sie Tableau Desktop auf einem Mac verwenden, geben Sie einen vollständig qualifizierten Domänennamen (beispielsweise "mydb.test.ourdomain.lan") anstelle eines relativen Domänennamens (beispielsweise "mydb" oder "mydb.test") ein.
Alternativ können Sie die Domäne der Liste der Suchdomänen für den Mac-Computer hinzufügen, sodass Sie zur Herstellung einer Verbindung nur den Servernamen angeben müssen. Zum Aktualisieren der Liste der Suchdomänen gehen Sie zu System-Voreinstellungen > Netzwerk > Erweitert, und öffnen Sie dann die Registerkarte DNS.
Standardmäßige virtuelle Warehouses in Snowflake
Wenn Sie eine Snowflake-Datenquelle erstellen, erstellen Sie sowohl ein Snowflake-Warehouse (für Rechenressourcen) als auch Snowflake-Datenbanken (für Datenressourcen). Sowohl Warehouses als auch Datenbanken benötigen Berechtigungen für den Zugriff. Sie können verschiedene Warehouses verwenden, um auf dieselbe Datenbank zuzugreifen, je nach erforderlicher Rechenleistung, vorausgesetzt, Sie verfügen über Berechtigungen für jedes Warehouse und jede Datenbank.
Wenn Sie eine Datenquelle anlegen, haben Sie die Möglichkeit, ein Warehouse aus einer Dropdownliste auszuwählen. Wenn Sie dieses Feld leer lassen und kein Warehouse auswählen, verwendet Tableau Ihr standardmäßiges virtuelles Snowflake-Warehouse. Wenn Sie diese Datenquelle oder Arbeitsmappe anschließend veröffentlichen, verwendet Tableau bei der Verbindung eines Benutzers das standardmäßige virtuelle Snowflake-Warehouse dieser Person.
Jedem Benutzer sollte ein Standard-Warehouse zugewiesen werden, damit Tableau dieses als Standard verwenden kann, um eine Arbeitsmappe aus einer Snowflake-Datenquelle zu öffnen.
Snowflake Server-Support für OAuth konfigurieren
Informationen zum Konfigurieren von OAuth für Verbindungen zwischen Tableau und Snowflake finden Sie unter Konfigurieren von OAuth für Snowflake-Verbindungen(Link wird in neuem Fenster geöffnet).
Verwenden eines Proxys für Snowflake
Sie können von Tableau aus über einen Proxy eine Verbindung zu Snowflake herstellen. Wenn Sie Tableau ab Version 2019.4 oder höher verwenden, können Sie dies im Dialogfeld „Connector“ konfigurieren, indem Sie die erforderlichen Parameter auf der Registerkarte Erweitert eingeben.
Beispiel:
proxy=http://proxyserver.company:80
Informationen zu den Parametern, die verwendet werden sollten, finden Sie in der Snowflake-Dokumentation(Link wird in neuem Fenster geöffnet).
Hinweis: Tableau verwendet keinen DSN, um eine Verbindung mit Snowflake herzustellen. Daher können Sie die Anweisungen in der Snowflake-Dokumentation zur Verwendung eines DSN ignorieren.
Wenn Sie eine Version von Tableau vor 2019.4 verwenden, können Sie dies konfigurieren, indem Sie die Parameter in eine TDC-Datei unter Verwendung von odbc-extras
eingeben.
Beispiel:
<connection-customization class='snowflake' enabled='true' version='19.1'>
<vendor name='snowflake' />
<driver name='snowflake' />
<customizations>
<customization name='odbc-connect-string-extras' value='proxy=http://proxyserver.company:80' />
</customizations></connection-customization>
Weitere Informationen finden Sie im Artikel Customize the Connection String for a Native Connector(Link wird in neuem Fenster geöffnet) (Anpassen der Verbindungszeichenfolge für einen nativen Connector).
Problembehebung
Leistung
Mithilfe der folgenden Informationen können Sie etwaige Leistungsprobleme beheben, die bei der Verwendung von Tableau mit Snowflake auftreten können.
Abrufgröße
Bei Verwendung unbegrenzter VARCHAR- oder VARBINARY-Felder gibt der Treiber eine Feldgröße von 16 M zurück. Dies führt dazu, dass Tableau eine kleine Abrufgröße verwendet, um innerhalb der Speichergrenzen zu bleiben. Das hat wiederum eine langsame Abfragegeschwindigkeit zur Folge. Hierfür gibt es mehrere Lösungsmöglichkeiten:
Schemaänderungen
Wenn Sie der Spaltendefinition eine Größe hinzufügen, z. B. VARCHAR(256), kann Tableau die optimale Abrufgröße berechnen.
TDC-Anpassungen
Sie können die Treiberparameter default_varchar_size oder default_binary_size verwenden. Sie können auch unter https://docs.snowflake.com/de/developer-guide/odbc/odbc-parameters(Link wird in neuem Fenster geöffnet) nachschauen, wie eine maximale Feldgröße für unbegrenzte Felder festgelegt wird.
Sie können die erweiterte Benutzeroberfläche oder eine TDC-Datei verwenden.
Sie müssen außerdem diese zusätzliche Funktion einrichten: CAP_ODBC_FETCH_BUFFERS_RESIZABLE.
Hinweis: Diese Lösung funktioniert nicht für Tableau Cloud, es sei denn, Sie verwenden Tableau Bridge.
Wenn Sie Tableau Bridge verwenden, können Sie die TDC-Datei auf dem Bridge-Host installieren, damit sie auf alle Verbindungen angewendet wird, die über diesen Host verlaufen. Beispiele dazu finden Sie weiter unten.
Verwenden Sie diese TDC-Datei, wenn Sie die Feldgröße für jede Datenquelle mithilfe der früheren Benutzeroberfläche anpassen möchten.
<connection-customization class='snowflake' enabled='true' version='10.0'>
<vendor name='snowflake' />
<driver name='snowflake' />
<customizations>
<customization name='CAP_ODBC_FETCH_BUFFERS_RESIZABLE' value='yes'/>
</customizations>
</connection-customization>
Verwenden Sie diese TDC-Datei, um die Anpassungen für alle Datenquellen durchzuführen.
<connection-customization class='snowflake' enabled='true' version='10.0'>
<vendor name='snowflake' />
<driver name='snowflake' />
<customizations>
<customization name='CAP_ODBC_FETCH_BUFFERS_RESIZABLE' value='yes'/>
<customization name='odbc-connect-string-extras' value='default_varchar_size=512;default_binary_size=512'/>
</customizations>
</connection-customization>
Häufig gestellte Fragen
Nachfolgend sind einige häufig auftretende Probleme und entsprechende Lösungsschritte aufgeführt.
Ich habe die Fehlermeldung "Dieses Feld XXX existiert nicht" erhalten, was soll ich tun?
Dieser Fehler tritt auf, wenn Sie ein berechnetes Feld verwenden, zum Arbeitsblatt hinzufügen und die Datenquelle durch die Snowflake-Daten ersetzen (benutzerdefinierte SQL).
Verwenden Sie die Funktion Feldverweise ersetzen, um den Fehler zu beheben. Weitere Informationen zum Ersetzen von Feldverweisen finden Sie unter Feldverweise ersetzen.
- Best Practices für die Verwendung von Tableau mit Snowflake(Link wird in neuem Fenster geöffnet) auf der Snowflake-Website (Registrierung erforderlich).
Siehe auch
- Einrichten von Datenquellen – fügen Sie dieser Datenquelle weitere Daten hinzu oder bereiten Sie Ihre Daten vor der Analyse vor.
- Erstellen von Diagrammen und Analysieren von Daten – Beginnen Sie mit Ihrer Datenanalyse.