热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

Oracle向MySQL迁移的注意点整理

1.表结构*数据库设计工具:连接Oracle拉取表字段信息,调整数据库类型后,CM创建MySQL版本的创建表语句*https:github.comhepengjuExcelVBAU

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数据库的特有问题, 可以多嵌套一层查询处理

```

 



推荐阅读
  • 安装mysqlclient失败解决办法
    本文介绍了在MAC系统中,使用django使用mysql数据库报错的解决办法。通过源码安装mysqlclient或将mysql_config添加到系统环境变量中,可以解决安装mysqlclient失败的问题。同时,还介绍了查看mysql安装路径和使配置文件生效的方法。 ... [详细]
  • EPICS Archiver Appliance存储waveform记录的尝试及资源需求分析
    本文介绍了EPICS Archiver Appliance存储waveform记录的尝试过程,并分析了其所需的资源容量。通过解决错误提示和调整内存大小,成功存储了波形数据。然后,讨论了储存环逐束团信号的意义,以及通过记录多圈的束团信号进行参数分析的可能性。波形数据的存储需求巨大,每天需要近250G,一年需要90T。然而,储存环逐束团信号具有重要意义,可以揭示出每个束团的纵向振荡频率和模式。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 关于我们EMQ是一家全球领先的开源物联网基础设施软件供应商,服务新产业周期的IoT&5G、边缘计算与云计算市场,交付全球领先的开源物联网消息服务器和流处理数据 ... [详细]
  • 数据库(外键及其约束理解)(https:www.cnblogs.comchenxiaoheip6909318.html)My ... [详细]
  • 解决VS写C#项目导入MySQL数据源报错“You have a usable connection already”问题的正确方法
    本文介绍了在VS写C#项目导入MySQL数据源时出现报错“You have a usable connection already”的问题,并给出了正确的解决方法。详细描述了问题的出现情况和报错信息,并提供了解决该问题的步骤和注意事项。 ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • Oracle10g备份导入的方法及注意事项
    本文介绍了使用Oracle10g进行备份导入的方法及相关注意事项,同时还介绍了2019年独角兽企业重金招聘Python工程师的标准。内容包括导出exp命令、删用户、创建数据库、授权等操作,以及导入imp命令的使用。详细介绍了导入时的参数设置,如full、ignore、buffer、commit、feedback等。转载来源于https://my.oschina.net/u/1767754/blog/377593。 ... [详细]
  • Python SQLAlchemy库的使用方法详解
    本文详细介绍了Python中使用SQLAlchemy库的方法。首先对SQLAlchemy进行了简介,包括其定义、适用的数据库类型等。然后讨论了SQLAlchemy提供的两种主要使用模式,即SQL表达式语言和ORM。针对不同的需求,给出了选择哪种模式的建议。最后,介绍了连接数据库的方法,包括创建SQLAlchemy引擎和执行SQL语句的接口。 ... [详细]
  • 在Oracle11g以前版本中的的DataGuard物理备用数据库,可以以只读的方式打开数据库,但此时MediaRecovery利用日志进行数据同步的过 ... [详细]
  • 本文介绍了Oracle存储过程的基本语法和写法示例,同时还介绍了已命名的系统异常的产生原因。 ... [详细]
author-avatar
淡定_一辈子
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有