最近做了几个项目,我对项目的要求(有些也是客户的要求)都是既要能用mysql数据库,又要能用oracle数据库,开发时尽量用mysql,等到发布时要求两者都能适应。因为两种数据库还是许多具体的应用有些不同,而我们开发中采用的技术又有各种,所以基本上都是采用手动去转换,具体转换过程如下:
一、分表结构及表数据两次导出。一次导出去转换之后导入oracle中比较麻烦,所以我们一般在mysql导出时将导出分成个结构及个数据两次导出。导出之后将个结构语句修改,具体修改如下:
二、对表的修改:
0、去掉`,`这个是mysql的特殊标示符,转换前要去掉
1、将所有的text替换成varchar2(4000)。有些转换工具将text是转换成blob或clob,我觉得那样不好,一般还是转换成varchar2(2000)或varchar2(4000)比较好。虽然采用spring或oracle10g可以clob当作string去处理,但是我觉得一般情况下还是转换成varchar2比较好,如果字段内容确实需要更长(varchar2最长是4000),在这种情况下采用clob就比较好了。
2、将所有的varchar替换成 varchar2 。
3、将tinyint(1)替换成number(1)。
4、将int(4)替换成number(4)。
5、去掉auto_increment选择项。oracle中没有自增属性,所以要去掉。
6、将NOT NULL default ''替换成default '' NOT
NULL。关键是这两个的顺序不能错,也不知道为什么,实际中总结出来的。
7、将