Daten über Datenbankserver-Verbindungstabellen hinweg abfragen
In vielen Fällen müssen Sie möglicherweise Tabellen in verschiedenen Datenbanken verknüpfen, die sich auf verschiedenen Servern befinden. Dies kann eine Herausforderung sein, aber es gibt Möglichkeiten, diese Datenintegration zu erleichtern.
Methode 1: Erstellen Sie einen Serverlink
sp_addlinkedserver
Mit gespeicherten Prozeduren können Sie eine Verbindung zwischen einem lokalen Server und einem Remote-Datenbankserver herstellen, eine sogenannte Serververbindung. Sobald die Verknüpfung hergestellt ist, können Sie in einer Abfrage auf die Remote-Tabelle verweisen, indem Sie dem Datenbanknamen des Remote-Servers dessen Datenbanknamen voranstellen.
Wenn Sie beispielsweise Tabelle MyDatabaseOnDB1
in MyTable
und Tabelle MyDatabaseOnDB2
in MyOtherTable
haben, können Sie diese mit der folgenden Abfrage verbinden:
<code class="language-sql">SELECT * FROM [MyDatabaseOnDB1].[dbo].[MyTable] tab1 INNER JOIN [DB2].[MyDatabaseOnDB2].[dbo].[MyOtherTable] tab2 ON tab1.ID = tab2.ID</code>
Methode 2: OPENQUERY verwenden
Alternativ können Sie OPENQUERY
verwenden, um eine SQL-Abfrage auf einem Remote-Server auszuführen und die Ergebnisse abzurufen. Mit dieser Methode kann der Remote-Server Abfragen optimieren und die Leistung verbessern. Dazu erstellen Sie eine temporäre Tabelle auf dem lokalen Server und füllen diese mit OPENQUERY
mit den Ergebnissen der auf dem Remote-Server ausgeführten Abfrage.
Zum Beispiel:
<code class="language-sql">-- 从其他数据库服务器获取数据 SELECT * INTO #myTempTable FROM OPENQUERY([DB2], 'SELECT * FROM [MyDatabaseOnDB2].[dbo].[MyOtherTable]') -- 现在我可以连接我的临时表来查看数据 SELECT * FROM [MyDatabaseOnDB1].[dbo].[MyTable] tab1 INNER JOIN #myTempTable tab2 ON tab1.ID = tab2.ID</code>
OPENQUERY
kann die Leistung verbessern und Zeit sparen, insbesondere wenn Abfragen zum Filtern großer Datensätze verwendet werden.
Ob Sie Server-Links verwenden oder OPENQUERY
, hängt von den spezifischen Anforderungen und Leistungsaspekten Ihrer Anwendung ab. Beide Ansätze bieten praktikable Lösungen für die Abfrage von Daten über Datenbankserver hinweg und ermöglichen eine effiziente Datenintegration.
Das obige ist der detaillierte Inhalt vonWie kann ich Tabellen über verschiedene Datenbankserver hinweg verknüpfen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!