|
项目进入开发阶段的时候,为了方便,一直使用Oracle数据库进行开发,所以很多sql语句都是在oracle能正常创建的,后期由于项目中嵌入了IBM的产品及其他因素,所以不得不使用db2数据库,切换数据库过程中的区别还是有点大,如:创建表、视图、存储过程、Ibatis支持等等、、、,下面就总结一下我从Oracle数据库切换到DB2数据库碰到的一些问题及如何解决。
1. 创建表字段类型的区别
Oracle
| DB2/400
| Oracle数据类型
| 注意事项
| DB2 UDB数据类型
| 注意事项
| DATE
| | DATE
TIME
TIMESTAMP l
| 如果只使用MM/DD/YYY,那么使用DATE类型。
l 如果只使用HH:MM:SS, 那么使用TIME类型。
l 如果要使用日期和时间,则使用时间戳类型(TIMESTAMP)
l 可以使用Oracle中的TO_CHAR()函数来取DATE的字串来分别与DB2/400的DATE、TIME相匹配。
| VARCHAR2(n)
| n<=4000
| CHAR(n)
VARCHAR(n) l
| 若n<=32766,则使用DB2/400中的CHAR类型、VARCHAR
| LONG
| n<=2GB
| VARCHAR(n)DL@bitsCN_com网管软件下载
CLOB(n) l
| 若n<=32K,则使用DB2/400中的CHAR类型、VARCHAR。
l 若32K=< n <=2GB,则使用CLOB。
| ROW&
LONG ROW
| n<=255
| CHAR(n) FORBIT DATA
VARCHAR(n) FOR BIT DATA
BLOB(n) l
| 若n<=32K, 则使用CHAR(n) FORBIT DATA 或
VARCHAR(n) FOR BIT DATA
l 若n<=2GB, 则使用BLOB(n)
| BLOB
| n<=4GB
| BLOB(n)
| 若n<=2GB, 则使用BLOB(n)
| CLOB
| n<=4GB
| CLOB(n)
| 若n<=2GB, 则使用CLOB(n)
| NCLOB
| n<=4GB
| DBCLOB(n)
| 若n<=2GB, 则使用DBCLOB(n/2)
| NUMBER
| | SMALLINT/INTEGER/BIGINT
DECIMAL(p,s)/NUMBER(p,s)
Float(n)/ REAL/DOUBLE l
| 若Oracle中定义NUMBER(p) 或 NUMBER(p,s), 则使用SAMLLINT/INTEGER/BIGINT
l 若Oracle中定义NUMBER(p,s), 则使用DECIMAL(p,s)
l 若Oracle中定义NUMBER,则使用FLOAT(n)/REAL/DOUBLE bbs.bitsCN.com
|
|
创建表区别基本上就这些了,创建表时根据区别修改一下字段类型基本上不会大的问题。
1. 创建视图区别
创建视图的时候不能使用 ORREPLACE ,不能这样使用排序语句
CREATE
VIEW VIEW_SSC AS
SELECT DATE_TIME FROM JBPM4_TASK TB ORDER BY TB.DATE DESC
2. 创建存储过程区别
a) 参数类型和参数名称的位置不同
db2: CREATE PROCEDURE PRO1 (IN OrgID int)
oracle:CREATE PROCEDURE PRO1 (OrgID IN int)
b) 同时作为输入输出参数的写法不同
db2: CREATE PROCEDURE PRO1 (INOUT OrgID int) INOUT连着写
oracle:CREATE PROCEDURE PRO1 (OrgID IN OUT int) IN OUT中间空格隔开,而且必须IN在OUT之前
c) 没有输入或输出参数时
db2: CREATE PROCEDURE PRO1 ()
oracle:CREATE PROCEDURE PRO1 不能有空的括号
d) 赋值语句写法不一样
db2: set var =..
oracle: var := ..
e) 异常处理不一样
f) CREATE PROCEDURE
db2:
CREATE PROCEDURESSCDBUSER.INDI_DEL_PRO
(INIDPARA VARCHAR(32),OUTRETURNPARA INTEGER)
LANGUAGE SQL
DYNAMIC RESULTSETS1
DETERMINISTIC
BEGIN
DECLARECOUNTID INTEGER;
DECLAREAPPLYNOD VARCHAR(20);
DECLARECATEGORYD VARCHAR(4);
SELECTCOUNT(ID)INTOCOUNTID FROMVIEW_SSC_INDIVIDUALFORMLIST WHEREID=IDPARA;
SETRETURNPARA =COUNTID;
SELECTAPPLY_NO,CATEGORYINTOAPPLYNOD,CATEGORYD FROMVIEW_SSC_INDIVIDUALFORMLIST WHEREID=IDPARA;
IFCATEGORYD='1001'THEN
DELETEFROMSSC_EVECT_LOAN_INFO WHEREID=IDPARA;
ELSEIF CATEGORYD='1002'THEN
DELETEFROMSSC_DAILY_LOAN_INFO WHEREID=IDPARA;
DELETEFROMSSC_DAILY_LOAN_DETAIL_INFO WHEREID=APPLYNOD;
ELSEIF CATEGORYD='1003'THEN
DELETEFROMSSC_EVECT_EXPENSE_INFO WHEREID=IDPARA;
DELETEFROMSSC_EVECT_EXPENSE_DETAIL_INFO WHEREID=APPLYNOD;
ELSEIF CATEGORYD='1004'THEN
DELETEFROMSSC_DAILY_EXPENSE_INFO WHEREID=IDPARA;
DELETEFROMSSC_DAILY_EXPENSE_DETAIL_INFO WHEREID=APPLYNOD;
ENDIF;
END
oracle:
CREATE ORREPLACEPROCEDURE"INDI_DEL_PRO" (IDPARA INVIEW_SSC_INDIVIDUALFORMLIST.ID%TYPE,RETURNPARA OUTNUMBER)
AS
APPLYNO VIEW_SSC_INDIVIDUALFORMLIST.APPLY_NO%TYPE;
CATEGORY VIEW_SSC_INDIVIDUALFORMLIST.CATEGORY%TYPE;
BEGIN
SELECTCOUNT(*)INTORETURNPARA FROMVIEW_SSC_INDIVIDUALFORMLIST WHEREID=IDPARA;
SELECTAPPLY_NO,CATEGORY INTOAPPLYNO,CATEGORYFROMVIEW_SSC_INDIVIDUALFORMLIST WHEREID=IDPARA;
IF CATEGORY='1001'THEN
DELETEFROMSSC_EVECT_LOAN_INFO WHEREID=IDPARA;
ELSIFCATEGORY='1002'THEN
DELETEFROMSSC_DAILY_LOAN_INFO WHEREID=IDPARA;
DELETEFROMSSC_DAILY_LOAN_DETAIL_INFO WHEREID=APPLYNO;
ELSIFCATEGORY='1003'THEN
DELETEFROMSSC_EVECT_EXPENSE_INFO WHEREID=IDPARA;
DELETEFROMSSC_EVECT_EXPENSE_DETAIL_INFO WHEREID=APPLYNO;
ELSIFCATEGORY='1004'THEN
DELETEFROMSSC_DAILY_EXPENSE_INFO WHEREID=IDPARA;
DELETEFROMSSC_DAILY_EXPENSE_DETAIL_INFO WHEREID=APPLYNO;
ENDIF;
END;
3. 如果工程是有用到Ibatis,那么Ibatis中sql语句写法也有些区别
a) Ibatis支持oracle数据库sql中可以带*号查询,db2不能使用select *from tablename;这是最主要的。
b) Ibatis支持oracle空值插入、更新,但是如果是db2映射值传空的话要必须要加上对应的字段类型
如:# remark:VARCHAR#
remark是属性值,VARCHAR是数据库中对应的字段类型。
总结了一下,方便以后查阅,同时也希望对看到这篇博客的朋友一些帮助,因为最近在解决这些问题时也花了不少时间。
|
|