连接字符串 || --> CONCAT
decode --> CASE WHEN ELSE END
行转列 wm_concat -->group_concat
nvl --> IFNULL --> 通用 COALESCE(字段,指定值)(返回括号里第一个不为null的数据,且字段值和指定值类型必须一样)
nvl2 --> IF ( ISNULL(字段名) , 0 , 1 ) --> 通用CASE 字段 WHEN null THEN 值2 WHEN '' THEN 值2 ELSE 值1 END as 别名;
sum,max --> 函数后面不能有空格
mysql不插入id,设置主键自增 (mysql主键自增,插入的时候不需要写ID.)
SEQ_I_ORDER_CUSTAPPEND_i.nextval,
mysql设置主键自增
ALTER TABLE 表名 CHANGE ID ID INT AUTO_INCREMENT
FULL OUTER JOIN 全连接mysql不支持 修改为 left outer join + right outer join
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开始不能获取到数据