Verbindungsserver (Datenbank-Engine)
Konfigurieren Sie einen Verbindungsserver, damit die SQL Server-Datenbank-Engine Befehle für OLE DB-Datenquellen außerhalb des instance von SQL Server ausführen kann. Normalerweise werden Verbindungsserver so konfiguriert, dass die Datenbank-Engine eine Transact-SQL-Anweisung ausführen kann, die Tabellen in einer anderen Instanz von SQL Server oder einem anderen Datenbankprodukt wie Oracle enthält. Viele Typen von OLE DB-Datenquellen können als Verbindungsserver konfiguriert werden, einschließlich Microsoft Access und Excel. Verbindungsserver bieten die folgenden Vorteile:
Die Fähigkeit, auf Daten von außerhalb von SQL Serverzuzugreifen.
Die Fähigkeit, verteilte Abfragen, Updates, Befehle und Transaktionen auf heterogenen Datenquellen im gesamten Unternehmen auszugeben.
Die Möglichkeit, verschiedene Datenquellen ähnlich zu adressieren.
Ein Verbindungsserver kann mit SQL Server Management Studio oder mit der Anweisung sp_addlinkedserver (Transact-SQL) konfiguriert werden. OLE DB-Anbieter variieren stark in Hinblick auf Typ und Anzahl der erforderlichen Parameter. Bei einigen Anbietern müssen Sie beispielsweise einen Sicherheitskontext für die Verbindung mithilfe von sp_addlinkedsrvlogin (Transact-SQL) bereitstellen. Einige OLE DB-Anbieter ermöglichen es SQL Server , Daten in der OLE DB-Quelle zu aktualisieren. Andere Anbieter stellen nur schreibgeschützten Datenzugriff bereit. Informationen zu den einzelnen OLE DB-Anbietern finden Sie in der jeweiligen Dokumentation des OLE DB-Anbieters.
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 Native Client OLE DB-Anbieter (PROGID: SQLNCLI11) ist der offizielle OLE DB-Anbieter für SQL Server.
Hinweis
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 mit dem SQL Server Native Client OLE DB-Anbieter und bestimmten anderen Anbietern getestet.
Einzelheiten zu Verbindungsservern
Die folgende Abbildung zeigt die Grundlagen einer Verbindungsserverkonfiguration.
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 Servervorhanden sein.
Wenn ein OLE DB-Anbieter eines Drittanbieters verwendet wird, muss das Konto, unter dem der SQL Server Dienst ausgeführt wird, über Lese- und Ausführungsberechtigungen für das Verzeichnis und alle Unterverzeichnisse verfügen, in denen 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.
Verwalten von Verbindungsserverdefinitionen
Beim Einrichten eines Verbindungsservers sollten die Verbindungsinformationen und Datenquelleninformationen in SQL Serverregistriert 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_addlinkedserverausführen.
Zeigen Sie Informationen zu den Verbindungsservern an, die in einer bestimmten instance von SQL Server definiert sind, indem Sie eine Abfrage für die sys.servers-Systemkatalogsichten ausführen.
Löschen Sie eine Verbindungsserverdefinition, indem Sie sp_dropserverausführen. Sie können mit dieser gespeicherten Prozedur auch einen Remoteserver entfernen.
Sie können Verbindungsserver auch mithilfe von SQL Server Management Studiodefinieren. 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öschenklicken.
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 in der Form linked_server_name.catalog..schema
object_name.
Hinweis
Verbindungsserver können so definiert werden, dass sie zurück auf den Server zeigen, auf dem sie definiert sind (zurücklaufen = loop back). Loopbackserver sind sehr nützlich, um eine Anwendung, von der verteilte Abfragen verwendet werden, in einem Netzwerk mit einem einzelnen Server zu testen. Loopbackverbindungsserver sind für Tests bestimmt und werden für viele Vorgänge, z. B. verteilte Transaktionen, nicht unterstützt.
Related Tasks
Erstellen von Verbindungsservern (SQL Server-Datenbank-Engine)
sp_addlinkedserver (Transact-SQL)
sp_addlinkedsrvlogin (Transact-SQL)