摘自:http://www.cnblogs.com/aji88/archive/2009/11/06/1597263.htmlhtml
对给定的连接服务器执行指定的传递查询。该服务器是 OLE DB 数据源。OPENQUERY 能够在查询的 FROM 子句中引用,就好象它是一个表名。OPENQUERY 也能够做为 INSERT、UPDATE 或 DELETE 语句的目标表进行引用。但这要取决于 OLE DB 访问接口的功能。尽管查询可能返回多个结果集,可是 OPENQUERY 只返回第一个。数据库
Transact-SQL 语法约定服务器
OPENQUERY ( linked_server ,'query' )
http://ddue.schemas.microsoft.com/authoring/2003/5 NS = "http://ddue.schemas.microsoft.com/authoring/2003/5"spa
表示连接服务器名称的标识符。code
在连接服务器中执行的查询字符串。该字符串的最大长度为 8 KB。server
OPENQUERY 不接受其参数的变量。htm
在 SQL Server 2000 和更高版本中,OPENQUERY 不能用于对连接服务器执行扩展存储过程。可是,经过使用四部分名称,能够在连接服务器上执行扩展存储过程。例如:blog
EXEC SeattleSales.master.dbo.xp_msver
任何用户均可以执行 OPENQUERY。用于链接到远程服务器的权限是从为连接服务器定义的设置中获取的。接口
如下示例将使用“用于 Oracle 的 Microsoft 访问接口”针对 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
如下示例针对示例 A 中建立的连接服务器使用 UPDATE
传递查询。
UPDATE OPENQUERY (OracleSvr, 'SELECT name FROM joe.titles WHERE id = 101') SET name = 'ADifferentName';
如下示例针对示例 A 中建立的连接服务器使用 INSERT
传递查询。
INSERT OPENQUERY (OracleSvr, 'SELECT name FROM joe.titles') VALUES ('NewTitle');
如下示例使用 DELETE
传递查询删除示例 C 中插入的行。
DELETE OPENQUERY (OracleSvr, 'SELECT name FROM joe.titles WHERE name = ''NewTitle''');