SQL Server 调用Oracle的存储过程

本文详细介绍了如何在SQL Server中通过Linked Server执行Oracle存储过程,包括Oracle Package定义、调用方法及注意事项,强调了动态SQL语句的使用和返回参数的处理。
摘要由CSDN通过智能技术生成
原文如下:
通过SQL  Linked  Server 执行Oracle 存储过程小结
1 举例
我们可以通过下面的方法在SQL Server中通过Linked Server 来执行Oracle 存储过程。
(1)  Oracle Package
PACKAGE Test_PACKAGE AS
       TYPE t_t is TABLE of VARCHAR2(30)
       INDEX BY BINARY_INTEGER;
       PROCEDURE Test_procedure1
      ( p_BATCH_ID IN VARCHAR2,
        p_Number IN number,
        p_MSG OUT t_t,
        p_MSG1 OUT t_t
      );
   END Test_PACKAGE;
PACKAGE BODY Test_PACKAGE AS
       PROCEDURE Test_procedure1
        ( p_BATCH_ID IN VARCHAR2,
          p_Number IN number,
          p_MSG OUT t_t,
          p_MSG1 OUT t_t
        )
        AS
        BEGIN
        p_MSG(1):='c';
        p_MSG(2):='b';
        p_MSG(3):='a';
p_MSG1(1):='abc';
        RETURN;
        COMMIT;
         EXCEPTION
            WHEN OTHERS THEN
                ROLLBACK;
        END Test_procedure1;
     END Test_PACKAGE;

(2) 在SQL Server中通过Linked Server 来执行Oracle 存储过程

declare @BatchID nvarchar (40)
declare @QueryStr nvarchar (1024)
declare @StatusCode nvarchar(100)
declare @
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值