案例如下:
内容如下(示例):
1. 连接字符串 || --> CONCAT
2. decode --> CASE WHEN ELSE END
3. 行转列 wm_concat
-->group_concat
4. nvl --> IFNULL --> 通用 COALESCE(字段,指定值)(返回括号里第一个不为null的数据,且字段值和指定值类型必须一样) nvl2 --> IF ( ISNULL(字段名) , 0 , 1 ) --> 通用CASE 字段 WHEN null THEN 值2 WHEN '' THEN 值2 ELSE 值1 END as 别名;
5. sum,max --> 函数后面不能有空格 mysql不插入id,设置主键自增
(mysql主键自增,插入的时候不需要写ID.) <if test="_databaseId != 'mysql'">
SEQ_I_ORDER_CUSTAPPEND_i.nextval,
mysql设置主键自增
6.ALTER TABLE 表名 CHANGE ID ID INT AUTO_INCREMENT FULL OUTER JOIN 全连接mysql不支持 修改为 left outer join + right outer join
7. update 语句的时候 set 不能带括号 select
distinct(CONCAT(CONCAT(t.sysno,'|'),t.parakey)) from pub_para t
str_to_date(date_format(DATE_SUB(20190101,INTERVAL 60
DAY),'%Y%m%d'),'%Y-%m-%d') 改为
DATE_FORMAT(DATE_SUB(sysdate(),INTERVAL 10 DAY),'%Y%m%d') minus
--> not exists( ) 要求查询出来的数据字段数量要一致. update tableA set (a,b,b) = (select a,b,b from tableB where ...) where ... mysql不支持这种写法,改为
update tableA left join tableB on ... set a=a,b=b,c=c where ...
to_date(‘19000101000000‘,‘yyyymmddhh24miss‘)改为select
str_to_date(‘1900-01-01 00:00:00‘,‘%Y-%m-%d %H:%i:%s‘),写法略有差异:
date_format(date,‘%Y-%m-%d‘) -------------->oracle中的to_char();
str_to_date(date,‘%Y-%m-%d‘) -------------->oracle中的to_date();
说明:
%Y:代表4位的年份
%y:代表2为的年份
%m:代表月, 格式为(01……12)
%c:代表月, 格式为(1……12)
%d:代表月份中的天数,格式为(00……31)
%e:代表月份中的天数, 格式为(0……31)
%H:代表小时,格式为(00……23)
%k:代表 小时,格式为(0……23)
%h: 代表小时,格式为(01……12)
%I: 代表小时,格式为(01……12)
%l :代表小时,格式为(1……12)
%i: 代表分钟, 格式为(00……59)
%r:代表 时间,格式为12 小时(hh:mm:ss [AP]M)
%T:代表 时间,格式为24 小时(hh:mm:ss)
%S:代表 秒,格式为(00……59)
%s:代表 秒,格式为(00……59) to_number(varchar2 or char,’format model’)-->cast(11 as unsigned int) /*整型*/,cast(11 as decimal(10,2))
/*浮点型*/,CAST("123" AS SIGNED INTEGER),带符号整型; SYSDATE-->now() /
SYSDATE() 注释oracle -- mysql --空格.
Oracle截取字符串的函数为:substr(字段名,起始位置,字符串长度) 起始位置可从0开始,截取结果和从1开始一样;
MySql截取字符串的函数为:substring(字段名,起始位置,字符串长度) 起始位置必须从1开始,0开始不能获取到数据