当前位置: 首页 > news >正文

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

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

转载于:https://www.cnblogs.com/softidea/p/5309234.html

相关文章:

  • 实习工作经历:代码在本地明明可以跑通,怎么放到服务器上就不行了呢?
  • 搭建一个包含多种Get请求和Post请求的工具类
  • 一致性hash原理与实现
  • 作为一个程序员需要了解多少网络方面的基础?网络基础总结(不断更新)
  • 四千字从源码分析ConcurrentHashMap的底层原理(JDK1.8)
  • redis学习笔记6--集合类型
  • 都2020年了,你还不知道count(1)和count(*)谁效率更高吗?
  • Linux下PF_PACKET的使用,RARP的server和client程序
  • 面试官:不会真有人不知道什么是线程池吧?
  • 从零搭建基于SpringBoot的秒杀系统(一):项目准备
  • 【总结】oracle恢复误删除数据,解除锁定的等sql语句
  • 从零搭建基于SpringBoot的秒杀系统(二):快速搭建一个SpringBoot项目
  • 重拾cgi——cgi dispatcher
  • 从零搭建基于SpringBoot的秒杀系统(三):首页、详情页编写
  • 从零搭建基于SpringBoot的秒杀系统(四):雪花算法生成订单号以及抢购功能实现
  • IP路由与转发
  • JavaScript学习总结——原型
  • Java程序员幽默爆笑锦集
  • JS笔记四:作用域、变量(函数)提升
  • Linux gpio口使用方法
  • PAT A1017 优先队列
  • PHP 的 SAPI 是个什么东西
  • React Transition Group -- Transition 组件
  • SAP云平台里Global Account和Sub Account的关系
  • Solarized Scheme
  • Work@Alibaba 阿里巴巴的企业应用构建之路
  • 精益 React 学习指南 (Lean React)- 1.5 React 与 DOM
  • 深度学习在携程攻略社区的应用
  • 源码安装memcached和php memcache扩展
  • 你对linux中grep命令知道多少?
  • 数据可视化之下发图实践
  • ​Linux Ubuntu环境下使用docker构建spark运行环境(超级详细)
  • ​TypeScript都不会用,也敢说会前端?
  • ​如何防止网络攻击?
  • # Apache SeaTunnel 究竟是什么?
  • ###C语言程序设计-----C语言学习(6)#
  • #HarmonyOS:Web组件的使用
  • #NOIP 2014# day.1 T2 联合权值
  • (42)STM32——LCD显示屏实验笔记
  • (8)Linux使用C语言读取proc/stat等cpu使用数据
  • (env: Windows,mp,1.06.2308310; lib: 3.2.4) uniapp微信小程序
  • (Matalb时序预测)PSO-BP粒子群算法优化BP神经网络的多维时序回归预测
  • (solr系列:一)使用tomcat部署solr服务
  • (搬运以学习)flask 上下文的实现
  • (附源码)计算机毕业设计SSM智能化管理的仓库管理
  • (论文阅读11/100)Fast R-CNN
  • (算法)N皇后问题
  • (转)Google的Objective-C编码规范
  • (转)如何上传第三方jar包至Maven私服让maven项目可以使用第三方jar包
  • .Net IE10 _doPostBack 未定义
  • .NET WebClient 类下载部分文件会错误?可能是解压缩的锅
  • .NET 除了用 Task 之外,如何自己写一个可以 await 的对象?
  • .NET/C# 阻止屏幕关闭,阻止系统进入睡眠状态
  • .netcore 获取appsettings
  • .Net下的签名与混淆