db2和oracle的一些区别

 项目中一直都是用db2,所以对db2也算有个一知半解,而对oracle则是知之甚少,一直苦于没有机会来练手。最近项目组在做db2到oracle的迁移,终于逮着机会了。今天简单说些在实际项目遇到得一些问题,以后再慢慢补充。同时也希望仁人志士多多指点。  
        由于这两天都是做存储过程的迁移,所以这里主要讲到的是db2和oracle两者存储过程以及一些系统函数的区别。

    1、创建PROCEDURE的参数的区别
        1)参数类型和参数名称的位置不同
            db2:    CREATE PROCEDURE PRO1 (IN OrgID int)
            oracle:CREATE PROCEDURE PRO1 (OrgID IN int)
        2)同时作为输入输出参数的写法不同
            db2:    CREATE PROCEDURE PRO1 ( INOUT OrgID int)    INOUT连着写
            oracle:CREATE PROCEDURE PRO1 (OrgID IN OUT int)    IN OUT中间空格隔开,而且必须IN在OUT之前
        3)没有输入或输出参数时
            db2:    CREATE PROCEDURE PRO1 ()    
            oracle:CREATE PROCEDURE PRO1 不能有空的括号

    2、变量定义和BEGIN END体的位置不同
        db2中变量定义在BEGIN END体内,并且每个变量都要用DECLARE声明;存储过程结束时,END后跟P1,并且不需要分号
        oracle中变量定义必须在BEGIN END体外,变量都不需要用DECLARE声明(有种说法是,第一个变量需要DECLARE,其他变量不需要);存储过程结束时,END后跟存储过程的名称,并且需要分号        
        db2:CREATE PROCEDURE PRO1()
                    LANGUAGE SQL    
                    P1: BEGIN
                         --变量定义
                         DECLARE INSERT_DATE TIMESTAMP; 
                         DECLARE ALLDEPT_NO  VARCHAR(20);

                         --具体操作
                         SELECT a FROM TAB_1;
                          .........
                    END P1
        
        oracle:  CREATE PROCEDURE PRO1
      
                      IS
                       --变量定义
                       INSERT_DATE TIMESTAMP; 
                       ALLDEPT_NO  VARCHAR(20);
   
                       BEGIN
   
                       --具体操作
                       SELECT a FROM TAB_1;
                       .........
                      END PRO1;

    3、控制语句的不同
        db2:     IF THEN ...... ELSEIF THEN .... END IF;
        oracle: IF THEN ...... ELSIF   THEN .... END IF;

    4、异常处理的不同

未完待续

转载于:https://www.cnblogs.com/snoopy/archive/2004/12/28/83122.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值