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

oracle迁移mysql数据库注意(转)的更多相关文章

  1. oracle迁移mysql数据库注意

    oracle转mysql修改: . substr() substr( string , 0, 10) 这里测试 必须从 第一位获取 既是 substr(string , 1 , 10)2. to_ch ...

  2. Mysql 利用拷贝data目录文件的方式迁移mysql数据库

    Mysql 利用拷贝data目录文件的方式迁移mysql数据库 步骤如下: 1.首先要确定data目录 这个问题困扰了我很久,因为网上的帖子大部分只是说拷贝mysql数据库目录下的data文件夹中的数 ...

  3. 在oracle配置mysql数据库的dblink

    本文介绍如何在oracle配置mysql数据库的dblink:虽然dblink使用很占资源:俗称“性能杀手”.但有些场景不得不使用它.例如公司使用数据库是oracle:可能其他部门或者CP合作公司使用 ...

  4. JAVA项目将 Oracle 转 MySQL 数据库转换(Hibernate 持久层)

    项目开发时用的是Oracle数据库,但为了更好的做分布式,做集群,我们要将数据库转成 MySQL! 在数据库迁移中首先要做的事是将 Oracle 的表结构以及数据 克隆到 MySQL 数据库. 这点不 ...

  5. SQL Server 和 Oracle 以及 MySQL 数据库

    推荐:https://www.zhihu.com/question/19866767 三者是目前市场占有率最高(依安装量而非收入)的关系数据库,而且很有代表性.排行第四的DB2(属IBM公司),与Or ...

  6. 一起学微软Power BI系列-使用技巧(1)连接Oracle与Mysql数据库

    说起Oracle数据库,以前没用过Oracle不知道,但是这1年用Oracle后,发现真的是想狂吐槽,特别是那个.NET驱动和链接字符串,特别奇葩.总归是和其他数据库不一样,标新立异,不知道为何.另外 ...

  7. 用sqlyog迁移mysql数据库

    本人大学大学基本就学怎么打游戏了,游戏玩的还不太好,大三的时候突然觉醒报了某培训,然后就出来工作了.这导致许多东西很不扎实,都是在工作中慢慢摸索.今天处理了一个关于mysql数据库迁移的问题,好好总结 ...

  8. 利用拷贝data目录文件的方式迁移mysql数据库

    其实迁移数据库,一般用sql文件就行,把A服务器数据库的表结构和数据等等导出,然后导入到B服务器数据库, 但是这次数据文件过大,大约有40个G,使用命令行导入,效果不是很好,经常在执行过程中报错.卡死 ...

  9. Sqlserver 连接oracle和mysql数据库 已经oracle导入sqlserver表数据

    SQL Server2012创建连接服务器到ORACLE11G 8,百思考不知道原因啊??突然我发现如下:链接服务器—〉访问接口—〉OraOLEDB.Oracle—〉允许进程内没有勾上,但是我想上面的 ...

随机推荐

  1. 基于Apriori算法的Nginx+Lua+ELK异常流量拦截方案 郑昀 基于杨海波的设计文档(转)

    郑昀 基于杨海波的设计文档 创建于2015/8/13 最后更新于2015/8/25 关键词:异常流量.rate limiting.Nginx.Apriori.频繁项集.先验算法.Lua.ELK 本文档 ...

  2. bat执行java程序的脚本解析

    使用java执行带Package的class文件java package1.package2.className  或java -cp .  package1.package2.className - ...

  3. C++中的对象指针

    指向对象的指针 在建立对象的时候,变异系统会给每一个对象分配一定的存储空间,以存放其成员. 对象空间的起始地址就是对象的指针.可以定义一个指针变量,用来存放对象的指针. 一个简单的示例1.1: #in ...

  4. [Usaco2008 Feb]Meteor Shower流星雨

    去年偶们湖南遭受N年不遇到冰冻灾害,现在芙蓉哥哥则听说另一个骇人听闻的消息: 一场流星雨即将袭击整个霸中,由于流星体积过大,它们无法在撞击到地面前燃烧殆尽, 届时将会对它撞到的一切东西造成毁灭性的打击 ...

  5. UVA 10003 Cutting Sticks

    题意:在给出的n个结点处切断木棍,并且在切断木棍时木棍有多长就花费多长的代价,将所有结点切断,并且使代价最小. 思路:设DP[i][j]为,从i,j点切开的木材,完成切割需要的cost,显然对于所有D ...

  6. extern 使用方法具体解释

    在C语言中,修饰符extern用在变量或者函数的声明前,用来说明"此变量/函数是在别处定义的.要在此处引用".(extern能够置于变量或者函数前,以标示变量或者函数的定义在别的文 ...

  7. Java程序员须知的七个日志管理工具(转)

    Splunk vs. Sumo Logic vs. LogStash vs. GrayLog vs. Loggly vs. PaperTrails vs. Splunk>Storm 英文原文:T ...

  8. MySQL错误:You are using safe update mode and you tried to update a table without a WHERE that uses a K

    转载自:http://blog.csdn.net/dragonpeng2008/article/details/7279590 Error: 1175 SQLSTATE: HY000 (ER_UPDA ...

  9. Spring3.0官网文档学习笔记(一)

    Part 1 Spring框架概述 Spring是模块化的,在应用中仅仅须要引入你所须要用到的模块的jar包,其余的jar包不用引入. spring框架支持声明式的事务管理,通过RMI或web ser ...

  10. 《Python学习手册》读书笔记

    之前为了编写一个svm分词的程序而简单学了下Python,觉得Python很好用,想深入并系统学习一下,了解一些机制,因此开始阅读<Python学习手册(第三版)>.如果只是想快速入门,我 ...