主要需要修改的有三个地方:
1.数据库驱动包,改为ojdbc-*.jar,
2.配置文件修改,将driver、url、用户名和密码修改,
3.数据访问层的修改,主要体现在SQL语句
一、数据库驱动包:
二、配置文件:
三、数据访问层(也是最麻烦的地方)
(2)自增方式,oracle需要创建序列,在语句中使用:序列名.nextval。如果你的java用到了框架,譬如hibernate,需要对id标签进行重新配置,加入自增序列的说明。
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;
(10)oracle没有group_concat;
(11)oracle的表名后面不能用as。
--分页方式
mysql使用limit,oracle使用rownum。
--函数
mysql的ifnull()对应oracle的nvl()
mysql的now()对应oracle的sysdate或systimestamp,可以在sysdate上直接使用运算符计算。
--主键
oracle主键为 number 类型,不支持自增
转为 mysql 后自动为 decimal 类型,此类型不能设置为自增
需要设置主键自增,手动将mysql主键改为int类型
--字符串
varchar2以下转为 varchar 类型,长度不变(oracle字节数在255以内)
varchar2以下转为 text 类型,字节数超过255自动变为text
--日期类型
Date类型转为datetime类型
(1) 取时间
oracle中sysdate,获取系统本地时间。mysql中,now()函数。
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’)
oracle -> mysql
YYYYmmdd -> %Y%m%d
YYYY-mm-dd -> %Y-%m-%d
yyyy-mm-dd hh24:mi:ss -> %Y-%m-%d %H:%i:%s
-----------------------------------
mysql日期加减
set @dt = now();
select date_add(@dt, interval 1 day); - 加1天
select date_add(@dt, interval 1 hour); -加1小时
select date_add(@dt, interval 1 minute); - 加1分钟
select date_add(@dt, interval 1 second); -加1秒
select date_add(@dt, interval 1 microsecond); -加1毫秒
select date_add(@dt, interval 1 week); -加1周
select date_add(@dt, interval 1 month); -加1月
select date_add(@dt, interval 1 quarter); -加1季
select date_add(@dt, interval 1 year); -加1年
MySQL adddate(), addtime()函数,可以用 date_add() 来替代
MySQL subdate(), subtime(),建议,用 date_sub() 来替代
MySQL 日期、时间相减函数:datediff(date1,date2), timediff(time1,time2)
-----------------------------------
net start mysql
net stop mysql
======Orcale====>>>>====Mysql======
一、数据类型
1.number -> (INT)
二、函数类型
1.length() -> char_length()
to_char(str) -> CAST(value AS char)
to_char() -> date_format(date,'%Y-%m-%d')
to_date() -> str_to_date(date,'%Y-%m-%d')
TO_NUMBER(exp) -> CAST(value AS datatype)
sys_guid()->UUID()
nvl(xxx,0) ->ifnull(xxx,0)
SUBSTR() -> SUBSTRING()
拼接符号|| -> concat(str, str1)
TRUNC() -> DATE()
NVL2(exp1,exp2,exp3) -> if(expr1,expr2,expr3)
add_months(SYSDATE,1)-> ADDDATE(NOW(), INTERVAL 1 MONTH)
ROWNUM ->limit
SYSDATE ->NOW()
三、特殊函数
1.instr()函数需要替换
四、转换mysql的字段类型
1.Oracle的NUMBER数值类型被自动转换为decimal类型,需手工做以下字段类型/结构修改:
(1)对于存放整型值的字段,需修改为int型。
(2)对于存放非整型字段(例如金额、单价等),如果在Oracle中未限定小数位数,则转换后小数位数自动变为 0,需根据实际需要修改小数位数。(金额8位,数量3位)
2、Oracle中varchar2的长度超过255的字段,会被自动转为text类型,需要手工改为varchar(实际长度)。
3、Oracle中的BLOB字段类型自动被转换为longblob,因为longblob类型的查询的时候比较慢,需要手工改为mediumBlob类型