oracle迁移mysql数据库注意(转)

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: oracle转mysql修改:1. substr() substr( string , 0, 10) 这里测试 必须从 第一位获取 既是 substr(string , 1 , 10)2. to_char() 只能用做oracle的函数,兼容oracle和mysql故 改为concat( … , ''); 这里 使用了两个, 一个 是将类似 int 转为 string 3.
oracle转mysql修改:

1. substr()
substr( string , 0, 10) 这里测试 必须从 第一位获取 既是 substr(string , 1 , 10)
2. to_char()
只能用做oracle的函数,兼容oracle和mysql故 改为concat( … , '');
这里 使用了两个, 一个 是将类似 int 转为 string
3. select * from (select * from table2) 这里 要加别名
4. nvl函数
被改为 case when length(str)>0 then '处理1' else '处理2' end
5. 使用了oracle 获取当前日期 并格式化成yyyy-MM-dd 和前一天的日期
解决,将获取时间改成了 传值, java 获取当前时间和前一天日期传给数据库(mysql 有自带 的缓存,如果使用了 函数,他不会缓存,另外 为了兼容 mysql 和 ora  cle)
6. oracle rownum
select @rownum:=@rownum+1 rownum
from (select @rownum:=0 from table)
7. to_char(to_date(t1.create_date,'yyyy-MM-dd hh24:mi:ss'),'dateFormat’)
修改为了
STR_TO_DATE(t1.create_date, '%Y-%m-%d %h:%i:%s’)
DATE_FORMAT(NOW(),'%Y-%m-%d %H:%i:%s'
8. 日期直接加减的含义不同了
比如Oracle中sysdate + 1 变成了sysdate() + interval 1 day(注意如果写成sysdate() + 1 语法还是正确的,但含义是错误的)
查询select sysdate() + 1 from dual 在MySQL得到比如 20080223153234(= 20080223153233 + 1)的数
9. select 'abc' || 'd' from dual 两个数据执行的结果不同(语法都能通过),MySQL要写成select concat('abc' , 'd')的形式
10. autocommit 注意 mysql 这个
11. 去掉别名
delete from table1 t where substr(t.trade_date,1,4)=?
这样的 sql 在 oracle 可以 但是在 mysql 需要把别名去掉
delete from table1 where substr(trade_date,1,4)=?
12. 存储过程
oracle 带参数声明
create or replace procedure THINKXDT.proc_update_seq(v_typename in varchar2,v_num out varchar2)
mysql 带参数声明
DROP PROCEDURE IF EXISTS `proc_update_seq`;
CREATE DEFINER=`root`@`%` PROCEDURE `proc_update_seq`(IN v_typename VARCHAR(200), OUT v_num VARCHAR(200))

oracle 参数为 (名称 IN/OUT 类型)
mysql 参数为 (IN/OUT 名称 类型) oracle 在存储过程声明变量 如下: 名称 类型; (在 begin 之前 create procedure() as 之后声明 mysql 在存储过程声明变量 如下: declare 名称 类型; (在begin 和 end 中声明)

oracle 在 存储过程 入参 有 带有 sys_refcursor 游标的参数,这样的mysql 不能用
oracle 使用了 表.Investor%TYPE 这种声明参数的时候 引用另外一个表的字段类型,mysql 里面最好直接 改为 那个类型

---------------------------------------------------------------------------
oracle 使用了 %rowtype 这种 声明一条结果集的 mysql不支持,解决(两部)
1.创建临时表
2.是吧这个里面的结果集字段 都单独的声明成一个 单独的变量
            oracle 如下:
var_name tablename%rowtype; --声明参数
-- 赋值
select o.* into tablename from oldtablename as o where rownum=1

-- 使用
tablename.a 直接就是 字段a的值

mysql 如下:
-- oralce 的声明参数改为了 创建临时表
CREATE TEMPORARY TABLE IF NOT EXISTS tablename (
SELECT *
FROM oldtablename t
WHERE tag_type=p_tag_type
ORDER BY create_date DESC, id DESC
limit 1
);
-- 表中的字段都要创建一个 变量
declare a int default -1;
declare b int;
-- 赋值
select t.a into a from tablename as t where limit 1;
select t.b into b from tablename as t where limit 1;
-- 使用
-- 直接 使用 变量 a b
-- 使用完后 需要
-- 清除临时表
TRUNCATE TABLE tmpTable;

---------------------------------------------------------------------------

判断 字符是否 为空 可以直接 LENGTH(字符) ,长度 <= 0 即为 空

oracle 中 存储过程可以return
mysql 需要 弄一个标记
如下:
begin 的 改为 label:begin 此时加了一个 label名字的标记
oracle 中 return 改为 leave label; 即可

oracle存储过程中给变量赋值 可以直接 赋值 var_name := 10;
mysql 需要这种修改 set var_name := 10; (mysql 必须加上set)

oracle 存储过程返回值 需要在参数里面加上 status_rc out sys_refcursor
然后
open status_rc for
select '-10000' as rscode, 'XXX不能为空' as rsmsg from dual;
return;
mysql 直接
select '-10000' as rscode,
'操作方向格式不正确(只能为‘+’或‘-’)' as rsmsg
from dual;
leave label;

mysql 存储过程中的异常处理 如下:

-- 异常处理 begin 后 声明变量的时候加上下面的

declare _err int default 0;

declare continue handler for sqlexception, sqlwarning, not found set _err=1;

-- 代码结尾 加上

if _err=1 then
rollback;
select '-10000' as rscode, 'XXXX异常!' as rsmsg from dual;
leave label;
end if;

 
13. 注意值,有些只 默认不是为空的 而是 为 null
14. to_char(sysdate, 'yyyy-mm-dd')
改为:DATE_FORMAT(now(), '%Y-%m-%d')
15. 如果字段类型是 varchar 但是 此字段值是数字,想以此字段排序,mysql 需要 查出来后 +0 就会自动转为 int 类型了

http://www.cnblogs.com/loveismile/p/5030911.html
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1天前
|
DataWorks Oracle 关系型数据库
DataWorks操作报错合集之尝试从Oracle数据库同步数据到TDSQL的PG版本,并遇到了与RAW字段相关的语法错误,该怎么处理
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
13 0
|
2天前
|
关系型数据库 MySQL 测试技术
【专栏】将 PostgreSQL 迁移到 MySQL 数据库
【4月更文挑战第29天】本文探讨了PostgreSQL数据库向MySQL迁移的过程、挑战及策略。迁移步骤包括评估规划、数据导出与转换、创建MySQL数据库、数据导入。挑战包括数据类型不匹配、函数和语法差异、数据完整性和性能问题。应对策略涉及数据类型映射、代码调整、数据校验和性能优化。迁移后需进行数据验证、性能测试和业务验证,确保顺利过渡。在数字化时代,掌握数据库迁移技能对技术人员至关重要。
|
12天前
|
SQL Oracle 安全
Oracle数据库中的事务和锁
【4月更文挑战第19天】Oracle数据库的事务和锁是确保数据完整性和并发控制的核心机制。事务遵循ACID原则,保证操作的原子性、一致性、隔离性和持久性。通过COMMIT或ROLLBACK来管理事务更改。锁包括共享锁(读)、排他锁(写)、行级锁和表级锁,用于控制并发访问。自动锁机制在DML操作时生效,防止数据冲突。事务和锁共同维护数据库的稳定和安全。
|
12天前
|
监控 Oracle 安全
Oracle用户事件触发器:数据库世界的“福尔摩斯”
【4月更文挑战第19天】Oracle用户事件触发器是数据库中的监控机制,类似于“福尔摩斯”,在用户执行特定操作时自动触发。它们关注用户行为而非数据变化,可用于权限检查、安全监控、性能优化等。通过DDL语句创建,需注意逻辑清晰、条件合适及定期更新,以适应数据库变化和业务发展。掌握其使用能有效保障数据安全与稳定。
|
12天前
|
SQL 存储 Oracle
Oracle语句级触发器:数据库的“隐形哨兵”
【4月更文挑战第19天】Oracle语句级触发器是数据库中的自动执行程序,当特定事件(如INSERT、UPDATE、DELETE)发生时,会针对整个SQL语句触发。以新员工入职记录日志为例,创建语句级触发器可自动在操作后向日志表插入信息,减少手动工作并提高性能。虽然无法处理行级详细信息,但在处理大量数据时,相比行级触发器更高效。掌握触发器使用能提升数据管理效率和安全性。
|
12天前
|
Oracle 关系型数据库 数据库
Oracle示例模式Scott:数据库世界的“小导游”
【4月更文挑战第19天】Oracle的Scott模式是数据库学习的向导,提供操作性的环境,包含表(如EMP和DEPT)、视图和索引。通过它,学习者能掌握基本语法和操作,如创建表、插入数据和编写查询。它是通往Oracle数据库世界的起点,帮助新手奠定基础,开启数据库探索之旅。
|
12天前
|
存储 Oracle 关系型数据库
Oracle的模式与模式对象:数据库的“城市规划师”
【4月更文挑战第19天】在Oracle数据库中,模式是用户对象的集合,相当于数据库的城市规划,包含表、视图、索引等模式对象。模式对象是数据存储结构,如表用于存储数据,视图提供不同查看角度,索引加速数据定位。良好的模式与模式对象设计关乎数据效率、安全和稳定性。规划时需考虑业务需求、性能、安全和可扩展性,以构建高效数据库环境,支持企业业务发展。
|
12天前
|
SQL Oracle 关系型数据库
Oracle SQL*Plus的SET命令:你的数据库会话“调色板”
【4月更文挑战第19天】Oracle SQL*Plus的SET命令是数据库会话的“调色板”,用于设置输出格式、反馈信息和各种偏好。它能调整PAGESIZE和LINESIZE以优化显示,控制ECHO和FEEDBACK开关以定制反馈,以及统计命令执行时间(TIMING)和调试SQL(VERIFY)。更高级的选项如HEADING和COLSEP可改善输出的可读性。通过灵活运用SET命令,能提升工作效率和体验,是数据库管理员和开发者的必备工具。
|
13天前
|
SQL Oracle 关系型数据库
常用数据库的分页语句(mySQL、oracle、PostgreSQL、SQL Server)
常用数据库的分页语句(mySQL、oracle、PostgreSQL、SQL Server)
|
存储 Oracle 关系型数据库
阿里云如何打破Oracle迁移上云的壁垒
2018第九届中国数据库技术大会,阿里云数据库产品专家萧少聪带来以阿里云如何打破Oracle迁移上云的壁垒为题的演讲。Oracle是指“数据库管理系统”,面对Oracle迁移上云的壁垒,阿里云如何能够打破它呢?本文提出了Oracle 到云数据库PPAS迁移的方案,这种迁移方案为什么比Oracle到 MySQL系列的迁移容易推动呢?答案即将揭晓。
10546 0

推荐镜像

更多