接上一篇对MyBatis-Plus多数据库支持,不废话直接上内容。
1、兼容处理
需要做到mysql和oracle都进行支持,建议将oracle表和列全都以大写命名,这样修改量小。
2、主键自增
11g及之前需要进行建立序列,12c以后支持自增,这个网上帖子比较多,大家可以自行更改,我们项目在初期就不许用自增所以不存在此转换问题。
3、对Mysql中使用的`符号进行剔除,条件使用' 单引号,查询语句中别名使用" 双引号。
4、mysql中使用ifnull语法的更改为nvl
5、对所有group by语法做监测,oracle查询语句只能包含group by后面字段或其聚合函数。
6、Oracle中表的别名不能用AS
, 列的别名可以用AS
7、分页mysql中使用 limit 关键字,而oracle中使用rownum,例如:mysql中使用Limit 1,oracle中使用rownum<=1(在xml中需要转换为rownum<=1),oracle需写在where条件之后,如果有条件需要加and连接,而mysql不需要。
如果存在order by语法需进行以下修改:
mysql
SELECT * FROM 表名 ORDER BY 字段名 DESC LIMIT 1
oracle
SELECT * FROM (
SELECT TMP.*, ROWNUM ROW_ID FROM (
SELECT * FROM 表名 ORDER BY 字段名 DESC
) TMP WHERE ROWNUM <= 1 )
WHERE ROW_ID > 0;
8、分组
mysql
SELECT 字段名,xxx... FROM 表名 GROUP BY 分组字段
oracle
SELECT
*
FROM (
SELECT tb.*, ROW_NUMBER ( ) OVER ( PARTITION BY tb.分组字段 ORDER BY tb.排序字段 DESC ) AS result
FROM (
SELECT 字段名,xxx... FROM 表名 -- 此处为查询sql,去掉`GROUP BY`分组条件,将分组字段加到上面 【 注:此sql的查询字段中要么全是聚合函数字段,要么都不是! 】
) tb
) WHERE result = 1
10、关键字,需加上双引号
11、字符串拼接
Mysql
CONCAT('%', 'xxx' , '%')
SELECT 字段名 FROM 表名 WHERE 字段名 LIKE CONCAT('%','helloworld','%')
Oracle
'%' || 'xxx' || '%'
SELECT 字段名 FROM 表名 WHERE 字段名 LIKE ('%' || 'helloworld' || '%')
12、字符串转数字
mysql
CAST(cpu_usage AS signed integer)
oracle
to_number(cpu_usage)
13、时间格式
- 字符串类型转时间类型: STR_TO_DATE -> TO_DATE
- 时间类型转指定字符串类型: DATE_FORMAT -> TO_CHAR
- 获取系统当前时间: NOW() -> SELECT SYSDATE FROM DUAL
-- 前:mysql 后:oracle
"%Y-%m-%d %H:%i:%S" "yyyy-MM-dd HH24:mi:ss"
"%Y-%m-%d %H:%i:%s" "yyyy-MM-dd HH24:mi:ss"
"%Y-%m-%d %H:%i" "yyyy-MM-dd HH24:mi"
"%Y-%m-%d %H" "yyyy-MM-dd HH24"
"%Y-%m-%d %h" "yyyy-MM-dd HH"
"%Y-%m-%d" "yyyy-MM-dd"
"%Y-%m" "yyyy-MM"
"%Y" "yyyy"
"%H" "HH24"
"%k" "HH24"
14、保留2位小数
ROUND(****,2)
15、时间差计算
mysql
TIMESTAMPDIFF(SECOND,createtime,recoverytime) AS difference
oracle
ROUND(TO_NUMBER( TO_DATE(recoverytime,'yyyy-MM-dd HH24:mi:ss')-TO_DATE(createtime,'yyyy-MM-dd HH24:mi:ss')
) * 24 * 60 * 60) AS difference
16、mysql中LOCATE 修改为Like写法
17、字符串截取
mysql :SUBSTRING oracle:SUBSTR
18、如果Mysql为text或者varchar过大的话会转换为oracle的clob类型就需要通过如下函数进行转换
dbms_lob.substr()。
如果有缺失、错误希望大家指出进行改进!!!