Oracle向MySQL迁移的注意点整理

摘要:
1.表结构*数据库设计工具:连接Oracle拉取表字段信息,调整数据库类型后,CM创建MySQL版本的create Table语句*https://github.com/hepengju/ExcelVBAUtils2.表数据*数据迁移工具:配置数据库的源和目标,配置要同步的表,通过JDBC直接查找集合,一次提交1000个条目*https://github.com/hepengju/datasync3.关键字
1. 表结构
    * 数据库设计工具: 连接Oracle拉取表字段信息, 调整数据库类型后, CM创建MySQL版本的创建表语句
    * https://github.com/hepengju/ExcelVBAUtils
2. 表数据
    * 数据迁移工具: 配置好数据库的来源和目标, 配置好需要同步的表, 直接JDBC查出来set进入, 1000条提交一次
    * https://github.com/hepengju/datasync
3. 关键字段
    * describe, specific 等关键字段需要加入转义符 `
4. SQL语句修改
    * 日期格式化与解析
        TO_CHAR(create_time          , 'yyyy-mm-dd hh24:mi:ss') ==> DATE_FORMAT(create_time          ,'%Y-%m-%d %H:%i:%s')
        TO_DATE('2017-01-06 10:20:30', 'yyyy-mm-dd hh24:mi:ss') ==> STR_TO_DATE('2017-01-06 10:20:30','%Y-%m-%d %H:%i:%s')
    * 其他相关函数
        ||         ==> concat()
        wm_concat  ==> group_concat
        to_number  ==> cast(xx as unsigned int)
        sys_guid() ==> replace(uuid(),'-','')
        nvl        ==> ifnull
trunc ==> truncate decode
==> case when trim(to_char(a.LIS_PRICE,'9,999,999,999,999,990.99')) ==> format(a.LIS_PRICE,2)

add_months( sysdate, xxxNum) ==> adddate(current_timestamp, interval xxxNum month)
insert all ==> insert values (),(),()
select 'x' from dual ==> select 'x' /* MySQL8已经支持from dual, 无需修改 */
with xxx as (select ... ) ==> 普通子查询 /* MySQL8已经支持CTE(with语句) */
   * rownum, row_number() over()的处理
where rownum = 1 ==> limit 1 /* oracle */ SELECT AR_TITLE AS "arTitle" , AR_DESC AS "arDesc" , ROWNUM AS "rownum" FROM CTC_SHOP_ARTICLE WHERE CAT_AR_ID = #{AID} /* mysql */ SELECT AR_TITLE AS "arTitle" , AR_DESC AS "arDesc" , @ROWNUM := @ROWNUM + 1 AS "rownum" FROM CTC_SHOP_ARTICLE E, (SELECT @ROWNUM := 0) R WHERE CAT_AR_ID = #{AID} /* oracle */ SELECT ROW_NUMBER() OVER(PARTITION BY PROC_INST_ID_ ORDER BY START_TIME_ DESC ) RN , ASSIGNEE_, OWNER_, NAME_, PROC_INST_ID_, ID_, START_TIME_, END_TIME_ FROM ACT_HI_TASKINST /* mysql */ SELECT @rn:= case when @pid = PROC_INST_ID_ then @rn + 1 else 1 end as rn , @pid:=PROC_INST_ID_ , ASSIGNEE_, OWNER_, NAME_, PROC_INST_ID_, ID_, START_TIME_, END_TIME_ FROM ACT_HI_TASKINST t, (select @pid:='', @rn:=0) as a ORDER BY PROC_INST_ID_,START_TIME_ DESC ``` * 其他注意点 ``` MySQL的字段默认值不支持函数, 比如在Oracle中设置某列默认值为to_char(sysdate,'yyyy-mm-dd HH24:mi:ss'), 则MySQL中需要在Java中设置 sql返回值的大小写问题: Oracle返回的都是大写, MySQL返回的是实际写法. 如果在mybatis的xml中使用Map进行接收的请注意修改 You can't specify target table 'xxx' for update in FROM clause MySQL数据库的特有问题, 可以多嵌套一层查询处理 ```

免责声明:文章转载自《Oracle向MySQL迁移的注意点整理》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Linux ALSA声卡驱动之五:移动设备中的ALSA(ASoC)C# WinForm 文件上传下载下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

win10安装mysql5.7.29教程以及错误处理

重新配了一台电脑,装了win10系统,安装mysql是出现了一些问题以及解决的方法。记录于此,避免下次安装遇到重复问题。 首先下载mysql5.7.29安装包,本次使用的是zip。已保存在百度网盘 链接:https://pan.baidu.com/s/1y8aahxloQEJTGXqmd95xsg 提取码:e3c6 也可以自己去官网下载: 下载地址:  h...

IdentitiServser4 + Mysql实现Authorization Server

 Identity Server 4官方文档:https://identityserver4.readthedocs.io/en/latest/ 新建2个asp.net core 项目使用空模板 Auth 身份认证服务 Client客户端 Auth项目打开安装相关依赖  IdentityServer4 和 EF 实体框架 Mysql EF Provid...

处理百万级以上的数据提高查询速度的方法

处理百万级以上的数据提高查询速度的方法: 1.应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使用索引而进行全表扫描。 2.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。 3.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而...

关于mysql installer 的安装和环境变量配置

MySQL针对不同的用户提供了2中不同的版本: MySQL Community Server:社区版。由MySQL开源社区开发者和爱好者提供技术支持,对开发者开放源代码并提供免费下载。 MySQL Enterprise Server:企业版。包括最全面的高级功能和管理工具,不过对用户收费。 下面讲到的MySQL安装都是以免费开源的社区版为基础。打开My...

MySQL-基础

SQL 是一门特殊的语言,专门用来操作关系数据库,不区分大小写 服务器端 安装服务器端:在终端中输入如下命令,回车后,然后按照提示输入 sudo apt-get install mysql-server 启动服务   sudo service mysql start 查看进程中是否存在mysql服务   ps ajx|grep mysql 停止服务   s...

MySql 获取当前节点及递归所有上级节点

-- MySql 获取当前节点及递归所有上级节点 -- 参数说明:resultField:查询返回字段,idd 要查询的资源ID值,idFieldName ID字段名,parentIdFieldName 上级ID字段名,tableName 表名,isContainMySelf 是否包含自己 DROP procedure IF EXISTS pro_g...