OPENQUERY (Transact-SQL)
在指定的連結伺服器上,執行指定的傳遞查詢。這部伺服器是 OLE DB 資料來源。您可以依照資料表名稱的相同方式,在查詢的 FROM 子句中參考 OPENQUERY。OPENQUERY 也可以被當作 INSERT、UPDATE 或 DELETE 陳述式的目標資料表加以參考。它是根據 OLE DB 提供者的功能而定。雖然查詢可以傳回多個結果集,但 OPENQUERY 只傳回第一個結果集。
語法
OPENQUERY ( linked_server ,'query' )
引數
linked_server
這是代表連結伺服器名稱的識別碼。'query'
這是在連結伺服器中執行的查詢字串。該字串的最大長度是 8 KB。
備註
OPENQUERY 不接受變數作為其引數。
在連結的伺服器上,OPENQUERY 無法用來執行擴充預存程序。不過,可以利用四部分名稱在連結的伺服器上執行擴充預存程序。例如:
EXEC SeattleSales.master.dbo.xp_msver
權限
任何使用者都可以執行 OPENQUERY。您可以從定義給連結伺服器的設定,取得用來連接到遠端伺服器的權限。
範例
A. 執行 SELECT 傳遞查詢
下列範例會利用 Microsoft OLE DB Provider for Oracle,對 Oracle 資料庫建立一個名稱為 OracleSvr 的連結伺服器。這個範例會接著對這個連結伺服器使用 SELECT 傳遞查詢。
[!附註]
這個範例假設已建立稱為 ORCLDB 的 Oracle 資料庫別名。
EXEC sp_addlinkedserver 'OracleSvr',
'Oracle 7.3',
'MSDAORA',
'ORCLDB';
GO
SELECT *
FROM OPENQUERY(OracleSvr, 'SELECT name, id FROM joe.titles');
GO
B. 執行 UPDATE 傳遞查詢
下列範例會對在範例 A 中建立的連結伺服器使用 UPDATE 傳遞查詢。
UPDATE OPENQUERY (OracleSvr, 'SELECT name FROM joe.titles WHERE id = 101')
SET name = 'ADifferentName';
C. 執行 INSERT 傳遞查詢
下列範例會對在範例 A 中建立的連結伺服器使用 INSERT 傳遞查詢。
INSERT OPENQUERY (OracleSvr, 'SELECT name FROM joe.titles')
VALUES ('NewTitle');
D. 執行 DELETE 傳遞查詢
下列範例會使用 DELETE 傳遞查詢來刪除範例 C 中插入的資料列。
DELETE OPENQUERY (OracleSvr, 'SELECT name FROM joe.titles WHERE name = ''NewTitle''');