oracle转mysql 薪资_Oracle转Mysql总结-阿里云开发者社区

参考文档

Oracle中的decode与mysql中的if

Oracle中 decode(Emergency,1,'紧急','普通')

mysql中

select a.title,if(a.Emergency=1,'紧急','普通')emergency from already_sign a

Select title,case Emergency when 1 then '紧急' else '普通' End as emergency from already_sign

字符串拼接

oracle:Oralce只支持两个字符串的拼接,若想拼接多个字符串可以嵌套使用concat, CONCAT(str1,str2)

Mysql支持多个字符串拼接: CONCAT(str1,str2,…)

日期处理

mysql : DATE_FORMAT(NOW(),'%Y-%m-%d %H:%i:%s')

oracle: TO_CHAR(SYSDATE,'YYYY-MM-DD hh24:mi:ss')

nvl函数

mysql: ifnull(A.USER_KPI,0)

oracle: NVL(A.USER_KPI,0)

to_number

oracle的to_number

mysql不需要

字符串格式化

mysql:CONCAT

oracle:TO_CHAR

关键字、保留字

涉及到关键字,mysql关键字需要加上``号

mysql: PARA_VALUE as KEY

oracle : PARA_VALUE as KEY

rownum

oracle自定义sql中如果使用了rownum=1

mysql中可以写成limit 1

大小写问题

在oracle中一般情况下不区分大小写

但在MySQL中,所使用操作系统的大小写敏感性决定了数据库名和表名的大小写敏感性。

解决的办法是把mysql的数据库名和oracle的大小写保持一致,

表名与应用程序中sql字符串中的表名保持一致,

如果应用程序中字段名用了双引号,那请把sql中的字段名大小写与双引号里的字符保持一致。

如果你的应用程序所引用的表名、字段没有统一大小写,那麻烦就大了。

字符串截取

mysql

截取log_data从逗号开始之后的字符:

SELECT substring_index(log_data,',',-1)

FROM nbts.log where event_id='150002' and log_id ='a2a421734c7e47dd8a8b';

截取log_data从逗号开始之前的字符:

SELECT substring_index(log_data,',',1)

FROM nbts.log where event_id='150002' and log_id ='a2a421734c7e47dd8a8b';

oracle

截取log_data从逗号开始之后的字符:

SELECT SUBSTR(log_data, INSTR(log_data, ',', 1, 1) +1) AS app_ver_id

FROM nbts.log where event_id='150002' and log_id ='a2a421734c7e47dd8a8b';

截取log_data从逗号开始之前的字符:

SELECT SUBSTR(log_data,0,INSTR(log_data, ',', 1, 1) - 1) AS app_ver_id

FROM nbts.log where event_id='150002' and log_id ='a2a421734c7e47dd8a8b';

主键生成策略

创建一个专门记录序列的表sequence,记录有当前序列号,序列的间隔如+1

创建记录当前序列的表

DROP TABLE

IF EXISTS sequence;

CREATE TABLE sequence (

NAME VARCHAR (50) NOT NULL,

current_value INT NOT NULL,

increment INT NOT NULL DEFAULT 1,

PRIMARY KEY (NAME)

) ENGINE = INNODB;

INSERT INTO sequence VALUES ('MovieSeq',3,5);

创建一个获取当前序列的function

DROP FUNCTION IF EXISTS currval;

CREATE FUNCTION currval (seq_name VARCHAR(50))

RETURNS INTEGER

CONTAINS SQL

BEGIN

DECLARE value INTEGER;

SET value = 0;

SELECT current_value INTO value

FROM sequence

WHERE name = seq_name;

RETURN value;

END;

获取下一个数值..先在sequence里面调用update当前最大数值+1然后再调用currval获得当前数值

DROP FUNCTION IF EXISTS nextval;

DELIMITER $

CREATE FUNCTION nextval (seq_name VARCHAR(50))

RETURNS INTEGER

CONTAINS SQL

BEGIN

UPDATE sequence

SET current_value = current_value + increment

WHERE name = seq_name;

RETURN currval(seq_name);

END$

DELIMITER ;

DROP FUNCTION IF EXISTS setval;

DELIMITER $

CREATE FUNCTION setval (seq_name VARCHAR(50), value INTEGER)

RETURNS INTEGER

CONTAINS SQL

BEGIN

UPDATE sequence

SET current_value = value

WHERE name = seq_name;

RETURN currval(seq_name);

END$

DELIMITER ;

如果以上语句执行有异常请先执行这句:set global logbintrustfunctioncreators=TRUE;

插入时的主键生成:

mysql: SELECT MMC.NEXTVAL('SEQ_MD_ENTITY_ATTRIBUTE')

oracle: select MMC.SEQ_MD_ENTITY_ATTRIBUTE.nextval from dual

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值