四、Oracle转Mysql总结
Oracle转Mysql总结(sql 转换)
参考⽂档
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_val from dual

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。