SQLServer链接服务器传递变量参数

本文引用微软官网的文章。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"提取行”

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值