zoukankan      html  css  js  c++  java
  • 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、异常处理的不同

    未完待续
  • 相关阅读:
    [国家集训队]墨墨的等式(同余最短路)
    [洛谷P2575]高手过招
    [CSP校内集训]rank
    杀人游戏(tarjan思维好题)
    骑士游戏(spfa好题)
    机房模拟测试4:计数类dp+水题+树上计数
    机房测试模拟2:模拟+数学+数位dp
    机房测试11:最小生成树(最小生成树+二分)
    机房测试模拟1(day2):矩阵+树上贪心+bfs+状压
    机房测试16:字符串专题(AC自动机+dp+kmp)
  • 原文地址:https://www.cnblogs.com/snoopy/p/83122.html
Copyright © 2011-2022 走看看