最近在做“去O”(去除Oracle数据库)的相关工作,需要将Oracle表结构转换成MySQL的表结构。这里面最重要的一点就是字段数据类型的变化。
1.ORACLE常用的数据类型与MySQL的对应关系
2.Oracle 中 varchar2(N) 与 varchar2(N char) 的区别
varchar(N)中是可以存储N个字节,而varchar(N char)是可以存储N个字符。
(对于UTF-8数据集来说:中文占两个字节,而英文占一个字节)
1、varchar2(N):可以存储N byte长度,与字符数无关;例如varchar2(3),可以存储3个byte长度,如'啊a'、'aaa',与字符数无关;
2、varchar2(N char):可以存储N个字符(包括字母和汉字),与字节(byte)长度无关;例如varchar2(3 char),可以存储3个字符(包括字母和汉字),如'啊啊啊'、'aaa'、'啊aa',与字节(byte)长度无关;
说明:对于字符集为UTF-8的MySQL数据库,varchar(10)不区分中英文,可以存储10个中文汉字,或者10个字母或数字。所以从Oracle的Varchar2类型转换成varchar类型,长度保持不变即可满足。
3.number数值类型转化
最复杂莫过于number(p,s),以这个举例来说明如何转换。
p是指有效位数,s是小数位,需要以p和s的实际取值来确定mysql的字段类型:
当p,s均为空时,此时需要参考表内的实际数值或者根据具体业务来确定转换的类型。参考实际数值时,可以采用获取表中max(length(column_name))-1(包含一个小数点)来确定p,用max(length(column_name)-instr(column_name ||'.','.'))(查找小数点后的位数)来确定s的值。
另外,一定要注意MySQL的int(2)这种写法,并不是smallint的别名,不管是int(2)还是int(8),实际都是int。
4.其他注意事项
除了最复杂的number类型以外,其他字段还有几点小建议:
(1)、除非要修改设计以支持秒以下级别的精度,Date最好转换为datetime而不要转为TIMESTAMP,因为TIMESTAMP存在2038年问题。
(2)、ORACLE FLOAT不要转为MYSQL FLOAT,要转为DOUBILE避免精度丢失。
(3)、处理char时,要注意最大的长度。
(4)、BLOB,CLOB转换时,MYSQL也有众多不同长度的类型选择,最好根据实际业务需要和业务数据来判断选择何种长度。