oracle代码改为mysql,java程序数据库oracle改为mysql需要改动哪些代码?怎么改?

主要需要修改的有三个地方: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。

以上是最常见的转移数据库时遇到的问题,如有生僻问题可自行搜索或在相关文档查询,篇幅限制无法全部写完。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值