主要需要修改的有三个地方:1.数据库驱动包,改为ojdbc-*.jar,2.配置文件修改,将driver、url、用户名和密码修改,3.数据访问层的修改,主要体现在SQL语句
一、数据库驱动包:
二、配置文件:
三、数据访问层(也是最麻烦的地方)
1、SQL语句:
(1)分页方式,mysql使用limit,oracle使用rownum。
(2)自增方式,oracle需要创建序列,在语句中使用:序列名.nextval。如果你的java用到了框架,譬如hibernate,需要对id标签进行重新配置,加入自增序列的说明。
(3)字段类型,对应数字oracle用NUMBER,字符串有VARCHAR2、NVARCHAR2,时间、日期是timestamp和date,超过4000的长字符串建议使用CLOB。
(4)函数
mysql的ifnull()对应oracle的nvl()。
mysql的now()对应oracle的sysdate或systimestamp,可以在sysdate上直接使用运算符计算。
oracle的时间,使用类似TO_DATE('2018-04-03 13:01:32','YYYY-MM-DD HH24:MI:SS')的方式表示。
mysql的date_format和time_format,oracle可以用类似TO_CHAR(sysdate,'YYYY-MM-DD HH24:MI:SS')
concat函数,oracle只能拼接两个,因此要么两两拼接,要么换成||拼接。
mysql的substring,oracle用substr处理。
去空,mysql只有trim,oracle有trim,ltrim,rtrim多种选择。
字符串长度,mysql是char_length(),oracle是length。
INSTR函数的参数个数,oracle多一个 ,使之可以从非1的位置开始执行:INSTR('abcd','a',2)。
mysql的if...case语句可以用oracle的decode函数代替。(5)oracle的SQL语句在书写上要求严格,譬如查询语句中,GROUP BY分组,mysql可以返回除分组字段外的其他字段的值,oracle不允许。
(6)mysql允许使用双引号操作字符串,oracle只能用单引号,程序内需要预先转换。
(7)如果脱离库表,oracle的查询或计算,需要使用虚拟表DUAL,譬如SELECT ASCII('A') VALUE FROM DUAL;
(8)insert语句,mysql可以连续,oracle不可以连续:
mysql:insert into 表 values(......),(......),(......);
oracle:insert into 表 values(......);
(9)判空,mysql允许使用!=null,oracle使用is not null;
(10)oracle没有group_concat;
(11)oracle的表名后面不能用as。
以上是最常见的转移数据库时遇到的问题,如有生僻问题可自行搜索或在相关文档查询,篇幅限制无法全部写完。