从Oracle转到Mysql前需了解的50件事
MySQL与Oracle 差异比较之一 数据类型
MySQL与Oracle 差异比较之二 基本语法
MySQL与Oracle 差异比较之三 函数
MySQL与Oracle 差异比较之四 条件循环语句
MySQL与Oracle 差异比较之五存储过程&Function
MySQL与Oracle 差异比较之六触发器
MySQL与Oracle 差异比较之七用户权限
MySQL与Oracle 差异比较之七其它
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')
mysql: ifnull(A.USER_KPI,0)
oracle: NVL(A.USER_KPI,0)
oracle的to_number
mysql不需要
mysql:CONCAT oracle:TO_CHAR
涉及到关键字,mysql关键字需要加上``号
mysql: PARA_VALUE as KEY oracle : PARA_VALUE as KEY
oracle自定义sql中如果使用了rownum=1 mysql中可以写成limit 1
在oracle中一般情况下不区分大小写
但在MySQL中,所使用操作系统的大小写敏感性决定了数据库名和表名的大小写敏感性。
解决的办法是把mysql的数据库名和oracle的大小写保持一致, 表名与应用程序中sql字符串中的表名保持一致,
如果应用程序中字段名用了双引号,那请把sql中的字段名大小写与双引号里的字符保持一致。
如果你的应用程序所引用的表名、字段没有统一大小写,那麻烦就大了。
截取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
作者:jackcooper 链接:https://www.jianshu.com/p/200f8e2d12dd 来源:简书 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
-------------------------------------------------------------------------------------------------------------------
这里使用PowerDesinger软件,自己可以去下载破解:
在PowerDesinger里找到 File -->> Reverse Engineer --->> Database
转换成mysql适用的数据库,从菜单栏上“Database”--->“Change Current DBMS”
这样oracle的数据库模型就变为mysql了,这里只要把sql导出就可以了
选择导出的路径,导出的文件名称
这样就成功了,你可以看自己设置的路径的sql就是mysql的sql文件了,其他数据库转换也是可以的。
———————————————— 版权声明:本文为博主「知春秋」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。 原文链接:https://blog.csdn.net/sinat_32366329/article/details/76402059