Verbindungsserver

Durch die Konfiguration von Verbindungsservern ist es SQL Server möglich, Befehle für OLE DB-Datenquellen auf Remoteservern auszuführen. Verbindungsserver bieten die folgenden Vorteile:

  • Zugriff auf Remoteserver.

  • Die Fähigkeit, verteilte Abfragen, Aktualisierungen, Befehle und Transaktionen auf heterogenen Datenquellen im gesamten Unternehmen auszugeben.

  • Die Möglichkeit, verschiedene Datenquellen ähnlich zu adressieren.

Verbindungsserverkomponenten

Eine Verbindungsserverdefinition gibt die folgenden Objekte an:

  • Einen OLE DB-Anbieter.

  • Eine OLE DB-Datenquelle.

Ein OLE DB-Anbieter ist eine DLL (Dynamic Link Library), die mit einer bestimmten Datenquelle interagiert und sie verwaltet. Eine OLE DB-Datenquelle identifiziert die spezielle Datenbank, auf die über OLE DB zugegriffen werden kann. Obwohl es sich bei Datenquellen, die über Verbindungsserverdefinitionen abgefragt werden, normalerweise um Datenbanken handelt, sind OLE DB-Anbieter für eine Vielzahl von Dateien und Dateiformaten verfügbar. Dazu gehören Textdateien, Kalkulationstabellendaten und die Ergebnisse aus Volltextsuchläufen.

Der Microsoft SQL Server SQL Native Client-OLE DB-Anbieter (PROGID: SQLNCLI10) ist der offizielle OLE DB-Anbieter für SQL Server.

HinweisHinweis

Die verteilten Abfragen von SQL Server sind jedoch so entworfen, dass sie mit jedem OLE DB-Anbieter zusammenarbeiten, der die erforderlichen OLE DB-Schnittstellen implementiert. SQL Server wurde jedoch nur für den SQL Server Native Client-OLE DB-Anbieter und bestimmte andere Anbieter getestet. Weitere Informationen finden Sie unter Mit SQL Server getestete OLE DB-Anbieter.

Einzelheiten zu Verbindungsservern

Die folgende Abbildung zeigt die Grundlagen einer Verbindungsserverkonfiguration.

Clientebene, Serverebene und Datenbankserver-Ebene

Verbindungsserver werden in der Regel für die Verarbeitung verteilter Abfragen verwendet. Führt eine Clientanwendung eine verteilte Abfrage über einen Verbindungsserver aus, analysiert SQL Server den Befehl und sendet Anforderungen an OLE DB. Für eine Rowsetanforderung kann eine Abfrage für den Anbieter ausgeführt oder eine Basistabelle vom Anbieter geöffnet werden.

Damit eine Datenquelle Daten über einen Verbindungsserver zurückgibt, muss der OLE DB-Anbieter (DLL) für diese Datenquelle auf demselben Server wie die Instanz von SQL Server vorhanden sein.

Wenn ein OLE DB-Anbieter eines Drittanbieters verwendet wird, müssen dem Konto, unter dem der SQL Server-Dienst ausgeführt wird, Lese- und Ausführungsberechtigungen für das Verzeichnis (und alle Unterverzeichnisse) erteilt worden sein, in dem der Anbieter installiert ist.

Verwalten von Anbietern

Eine Gruppe von Optionen steuert, wie SQL Server OLE DB-Anbieter lädt und verwendet, die in der Registrierung angegeben werden. Weitere Informationen finden Sie unter Konfigurieren von OLE DB-Anbietern für verteilte Abfragen.

Verwalten von Verbindungsserverdefinitionen

Beim Einrichten eines Verbindungsservers sollten die Verbindungsinformationen und Datenquelleninformationen in SQL Server registriert werden. Nach der Registrierung kann über einen einzelnen logischen Namen auf diese Datenquelle verwiesen werden.

Sie können gespeicherte Prozeduren und Katalogsichten zum Verwalten von Verbindungsserverdefinitionen verwenden:

  • Erstellen Sie eine Verbindungsserverdefinition, indem Sie sp_addlinkedserver ausführen.

  • Zeigen Sie Informationen zu den in einer bestimmten Instanz von SQL Server definierten Verbindungsservern an, indem Sie eine Abfrage der sys.servers-Systemkatalogsichten ausführen.

  • Löschen Sie eine Verbindungsserverdefinition, indem Sie sp_dropserver ausführen. Sie können mit dieser gespeicherten Prozedur auch einen Remoteserver entfernen.

Sie können Verbindungsserver auch mithilfe von SQL Server Management Studio definieren. Klicken Sie im Objekt-Explorer mit der rechten Maustaste auf Serverobjekte, klicken Sie auf Neu, und klicken Sie dann auf Verbindungsserver. Sie können eine Verbindungsserverdefinition löschen, indem Sie mit der rechten Maustaste auf den Namen des Verbindungsservers und dann auf Löschen klicken.

Wenn Sie eine verteilte Abfrage auf einem Verbindungsserver ausführen, sollten Sie einen vollqualifizierten vierteiligen Tabellennamen für jede Datenquelle einschließen, die abgefragt werden soll. Dieser vierteilige Name sollte die Form linked_server_name.catalog**.schema.**object_name aufweisen. Weitere Informationen finden Sie unter Verteilte Abfragen.

HinweisHinweis

Verbindungsserver können so definiert werden, dass sie auf den Server, auf dem sie definiert sind, zurückzeigen (Loopback). Loopbackserver sind sehr nützlich, um eine Anwendung, die verteilte Abfragen verwendet, in einem Netzwerk mit einem einzelnen Server zu testen. Loopback-Verbindungsserver dienen zu Testzwecken und werden für viele Vorgänge wie verteilte Transaktionen nicht unterstützt.