DB2是IBM公司研制的一种关系型数据库系统。DB2主要应用于大型应用系统,具有较好的可伸缩性,可支持从大型机到单用户环境,应用于OS/2、 Windows等平台下。

    ORACLE数据库系统是美国ORACLE公司(甲骨文)提供的以分布式数据库为核心的一组软件产品,是目前最流行的客户/服务器(CLIENT/SERVER)或B/S体系结构的数据库之一。

   在命令方面,二者主要有如下差别: 


1、DB2 访问前10行数据与 Oracle区别


DB2 :    

select * from tabname fetch first 10 rows only 

 

  Oracle :    

 
 tabname
 

  查询语句 

 

  Db2:不提供隐形转换 

 
 tabname
 

  oracle:提供隐形转换 

 
 tabname
 

  2、DB2 Insert into 与Oracle区别 

 

  DB2 允许有类似这样多行插入: 

 
 tabname
 

  (1212,'cemy',20,'sales',3,90000,30000);  

 

  oracle:   

 
 tabname
 

  ,20,'sales',3,1000,3000)                                                    

 

  3、DB2 Update 与Oracle Update 

 

  Db2 

 
 tabname
 
 tabname
 

  Oracle: 

 
 tabname
 

  已更新 1 行。I 

 

  4、取得 
 系统日期 

 

  Oracle: 

 

  Select sysdate from dual; 

 

  DB2: 

 

  Select current timestamp from sysibm.sysdummy1; 

 

  5、转换日期时间到字符类型: 

 

  Oracle   

 

  TO_CHAR(date_expression_r_r, 'YYYY-MM-DD')   

 

  TO_CHAR(date_expression_r_r, 'HH24:MI:SS')   

 

  DB2   

 

  CHAR(date_expression_r_r,ISO)   

 

  CHAR(time_expression_r_r,ISO)   

 

  6、转换日期时间字符串到日期时间类型: 

 

  Oracle   

 

  TO_CHAR(date_expression_r_r, 'YYYY-MM-DD')   

 

  TO_CHAR(date_expression_r_r, 'HH24:MI:SS')   

 

  DB2   

 

  DATE('2005-05-20')   

 

  TIME('18:59:59')   

 

  TIEMSTAMP('2007-2-1', '21:12:12')   

 

  TIEMSTAMP('2007-2-1 21:12:12') 

 

  DB2也有TO_CHAR 和 TO_DATE函数,但只能提供固定的转换格式,如下 

 

  TO_CHAR (timestamp_expression_r_r,'YYY-MM-DD HH24:MI:SS')   

 

  TO_DATE (string_expression_r_r, 'YYY-MM-DD HH24:MI:SS')   

 

  7、快速清空大表 

 

  Oracle: 

 
 tabname
 

  DB2: 

 
 tabname
 

  8、创建类似表 

 

  Oracle: 

 

  create table a as select * from b ; 

 

  DB2: 

 

  create table a like b ;  

 

  9、修改字段长度或类型: 

 

  ORACLE: 

 

  ALTER TABLE NODES MODIFY NODE_NAME varchar(32); 

 

  DB2: 

 

  alter table NODES ALTER NODE_NAME SET DATA TYPE varchar(32);  

 

  10、空值处理得到abc 

 

  Oracle: 

 

  SELECT 'abc' || c1 FROM t1 (c1 IS NULL)   

 

  DB2 : 

 

  SELECT 'abc‘ || COALESCE(c1,'') FROM t1  

 

  11、创建 indexes  

 

  Oralce: 

 

  Create TABLE T1 .............IN DATA_TA 

 

  Create Index ........ ON T1  ...... IN INDX_TS 

 

  DB2: 

 

  Create TABLE T1 ........ IN DATA_TS INDEX IN INDX_TS 

 

  Create INDEX  .....ON T1 

 

  12、更改列名 

 

  oracle : 

 
 tabname
 

  db2   

 

  不提供更改列名功能(解决办法同删除,或者通过建立一个新视图解决) 

 

  13、更改列类型 

 
 tabname
 
 tabname
 

  14 创建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 不能有空的括号 

 

  变量定义和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); 

 

             --具体操作  www.2cto.com   

 

             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; 
 
 

  15、控制语句的不同 

 

   db2:     

 

   IF …THEN ......ELSEIF THEN .... END IF; 

 

   oracle:  

 

  IF …THEN ......ELSIF  THEN .... END IF; 

 

  16、如何执行脚本SQL文件 

 

  Oracle:  

 

  @$PATH/filename.sql;  

 

  DB2:   

 

  db2 -tvf $PATH/filename.sql  

 

  17、查看当前用户的表和视图 

 

  DB2: 

 

  LIST   TABLES  

 

  ORACLE:    

 

  SELECT   *   FROM   TBAB; 

 

  DB2:DROP   TABLE删除表和定义。LIST   TABLES发现表不存在了。  

 

  ORACLE:DROP   TABLE删除表的内容保留表的定义。可以看到表。