本文引用微软官网的文章。http://support.microsoft.com/kb/314520/zh-cn#top
查询链接的服务器时, 经常执行的使用 OPENQUERY、 OPENROWSET,或 OPENDATASOURCE 语句直接传递查询。 您可以查看示例 SQL Server 联机丛书中看到如何执行此操作通过使用预定义的 TRANSACT-SQL 字符串但没有示例,说明如何将变量传递给这些函数。 本文提供了三个示例,说明如何将变量传递给链接的服务器查询。
若要将变量传递给传递的函数之一,您必须生成一个动态查询。
包括引号的任何数据需要特定的处理。 有关详细信息请参阅 SQL Server 联机丛书中的使用 char 和 varchar 数据主题,请参阅以下 Microsoft 知识库中文章:
156501 (http://support.microsoft.com/kb/156501/EN-US/ ) INF: QUOTED_IDENTIFIER 和与单一的引号的字符串
传递基本值
直接用
SELECT * FROM OPENQUERY(hisqyxx,'select * from hisqyxx.dbo.QYUserInfo') //hisqyxx远程链接服务器名
在基本的 TRANSACT-SQL 语句已知,但必须在一个或多个特定的值传递时使用类似于下面的示例代码:
DECLARE @TSQL varchar(8000), @VAR char(2)
SELECT @VAR = 'CA'
SELECT @TSQL = 'SELECT * FROM OPENQUERY(MyLinkedServer,''SELECT * FROM pubs.dbo.authors WHERE state = ''''' + @VAR + ''''''')'
EXEC (@TSQL)
传递整个查询
您必须传递整个 TRANSACT-SQL 查询或链接的服务器 (或两者),名称中使用的代码类似于下面的示例:
DECLARE @OPENQUERY nvarchar(4000), @TSQL nvarchar(4000), @LinkedServer nvarchar(4000)
SET @LinkedServer = 'MyLinkedServer'
SET @OPENQUERY = 'SELECT * FROM OPENQUERY('+ @LinkedServer + ','''
SET @TSQL = 'SELECT au_lname, au_id FROM pubs..authors'')'
EXEC (@OPENQUERY+@TSQL)
使用该 Sp_executesql 存储过程
若要避免 multi-layered 的报价单,使用类似于下面的示例的代码:
DECLARE @VAR char(2)
SELECT @VAR = 'CA'
EXEC MyLinkedServer.master.dbo.sp_executesql
N'SELECT * FROM pubs.dbo.authors WHERE state = @state',
N'@state char(2)',
@VAR
另外的方式(使用AT,感觉更好用些)
1.EXEC('select * from table_name ') AT 链接服务器名称
2.调研存储过程 --执行Oracle上存储过程
EXEC('BEGIN UP_PROCEDURE(''x'',''x''); END;') AT 链接服务器名称
与以上的区别在于执行update时.报“无法使用书签从链接服务器的OLE DB 访问接口 "OraOLEDB.Oracle"提取行”