转自:http://blog.sina.com.cn/s/blog_4f9ce8f30100q52i.html 导言:最近的数据超市项目需要从SQLServer 迁移 到MySql。在之前并没有很多 数据库 迁移 方面的经验,所以也不知道 迁移 需要花费多久,都要做什么工作。通过几天的工作,项目已经顺利 迁移 到M
转自:http://blog.sina.com.cn/s/blog_4f9ce8f30100q52i.html
导言:最近的数据超市项目需要从SQLServer迁移到MySql。在之前并没有很多数据库迁移方面的经验,所以也不知道迁移需要花费多久,都要做什么工作。通过几天的工作,项目已经顺利迁移到MySql上。该文档总结了迁移的经验,同时也方便以后数据库迁移。
1、数据库迁移需要做的工作
1.1
1.2
1.3
1.4
1.5
2、常用数据库中在开发方面的不同
2.1
2.2
2.3
2.4
2.5
3、ORM工具与迁移
使用hibernate、ibatis,在数据库迁移中的不同效率
4、各数据库的不同数据类型比较及参考资料
4.1、MySQL中的建表SQL
4.2、Java到SQL数据类型影射表
4.3、
4.4、ORACLE与SQLSERVER、MYSQL的数据类型对照表
1、数据库迁移需要做的工作
1、1
1.1.1
1.1.2
1.1.3
1、2
1.2.1设置数据库的编码,防止中文乱码
1)、最简单的修改方法,就是修改mysql的my.ini文件中的字符集键值,
如:default-character-set
(character_set_server
修改完后,重启mysql的服务,service
2)、还有一种修改字符集的方法,就是使用mysql的命令,如:
mysql>
mysql>
如果:没有设置前两条,可以通过以下方式实现编码:
a
(每个见表语句后加:ENGINE=MyISAM
1.2.2
即使MySQL中有bit,但SQLServer中的bit类型(取0或1,分别对应了bool的true和false)的变量在MySQL中,不能顺利导入。需要将其设置为tinyint(1),才能顺利导入。
12.3导入数据
1、3
1.4
SQLServer的数据库连接:
datamart_driver=com.microsoft.sqlserver.jdbc.SQLServerDriver
datamart_url=jdbc:sqlserver://172.16.6.23:1433;DatabaseName=datamart
MySql的数据库连接:
datamart_driver=com.mysql.jdbc.Driver
datamart_url=jdbc:mysql://172.16.6.23:3306/datamart
Oracle的数据库连接:
datamart_driver=oracle.jdbc.driver.OracleDriver
datamart_url=jdbc:oracle:thin:@172.16.6.26:1521:datamart
用户名和密码都是:
datamart_username=root
datamart_password=sd100301
2、常用数据库中在开发方面的不同
2.1
2.1
Oracle中的分页:可以采用rownumber实现;SQLServer中的分页,采用内容函数row_number()
Oracle中的SQL:
select rn,first_name,salary from(select rownum as rn,frist_name,salary from (select first_name,salary from s_emp order by salary)) where rn between 11 and 20
SQLServer中的SQL:
select * from( select row_number() over(order by salary desc) as rownumber,* from s_emp where salary>3000 ) as tb where rownumber between 11 and 20;
MySQL中基本的SQL:
select * from apiinfo where id<br> <p><span><strong>2.2 </strong></span><wbr><span><strong>内置函数</strong></span></wbr></p> <p><strong><strong>数据库</strong></strong>中有许多内置函数,不少是用于处理字符串、日期等的。</p> <p>SQLServer的len(),相当于MySQL的length(),相当于Oracle的Len().</p> <p><span><strong>2.3 </strong></span><wbr><span><strong>自增</strong></span></wbr></p> <p>2.3.1 <wbr>自增关键字 <wbr></wbr></wbr></p> <p>Oralce: <wbr>SQLServer: <wbr>identity <wbr>MySQL:auto_increment</wbr></wbr></wbr></p> <p><span>2.3.2 </span><wbr><span>Oracle中的自增(序列号):</span></wbr></p> <p>定义:CREATE <wbr>SEQUENCE <wbr>emp_sequence <wbr> <wbr> <wbr> <wbr> <wbr> <wbr> <wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></p> <p>INCREMENT <wbr>BY <wbr>1 <wbr> <wbr> <wbr>-- <wbr><span>每次加几个 <wbr> <wbr></wbr></wbr></span><span> <wbr> <wbr> <wbr> <wbr> <wbr></wbr></wbr></wbr></wbr></wbr></span></wbr></wbr></wbr></wbr></wbr></wbr></p> <p>START <wbr>WITH <wbr>1 <wbr> <wbr> <wbr> <wbr> <wbr>-- <wbr><span>从</span><span>1</span><span>开始计数 <wbr> <wbr></wbr></wbr></span><span> <wbr> <wbr> <wbr> <wbr> <wbr></wbr></wbr></wbr></wbr></wbr></span></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></p> <p>NOMAXVALUE <wbr> <wbr> <wbr> <wbr> <wbr> <wbr> <wbr>-- <wbr><span>不设置最大值 <wbr> <wbr></wbr></wbr></span><span> <wbr> <wbr> <wbr> <wbr> <wbr></wbr></wbr></wbr></wbr></wbr></span></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></p> <p>NOCYCLE <wbr> <wbr> <wbr> <wbr> <wbr> <wbr> <wbr> <wbr> <wbr> <wbr>-- <wbr><span>一直累加,不循环 <wbr> <wbr></wbr></wbr></span><span> <wbr> <wbr> <wbr> <wbr> <wbr>CACHE <wbr>10;</wbr></wbr></wbr></wbr></wbr></wbr></span></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></p> <p>使用:emp_sequence.CURRVAL <wbr> <wbr> <wbr> <wbr> <wbr>emp_sequence.NEXTVAL <wbr> <wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></p> <p>2.3.3 <wbr>自增带来的问题及其解决</wbr></p> <p>问题:(oracle中的自增字段,如果它的值不是连续的,并且您将其做为主键,那么<strong>迁移</strong>到其它<strong><strong>数据库</strong></strong>时候,那些不连续的值发生了改变。而其它表是与该字段关联的,这样程序就会出错)</p> <p>解决方式:在目标<strong><strong>数据库</strong></strong>中建立统一的表,并有同样的字段但不自增;导入数据后,再修改表的结构,使得该字段自增。</p> <p>2.3.4 <wbr>自己实现id字段的自增的SQL语句</wbr></p> <p>insert <wbr>into <wbr>orderApi <wbr>(id,ordernumber,apiid)</wbr></wbr></wbr></p> <p>select <wbr>distinct <wbr>IFNULL((select <wbr>max(id)+1 <wbr>from <wbr>orderApi),1),#ordernumber#,#apiid# <wbr></wbr></wbr></wbr></wbr></wbr></wbr></p> <p>from <wbr>orderApi <wbr> <wbr>group <wbr>by <wbr>id</wbr></wbr></wbr></wbr></wbr></p> <p>2.4 <wbr>存储过程</wbr></p> <p>不同的<strong><strong>数据库</strong></strong>存储过程相差的比SQL间的差异到大,所以项目中的存储过程需要改不少地方。或者,如果对性能影响不大,可以不用存储过程。</p> <p><span><strong>2.5 </strong></span><wbr><span><strong>模糊查询</strong></span></wbr></p> <p>在<span>SQLServer</span><span>中,模糊查询可以使用 <wbr></wbr></span></p> <p></p> <pre name="code" class="sql">select * from apiinfo where cnname like #key#+'%';
但在MySql中,则需改为:
select * from apiinfo where cnnamelike '%$key$%' or select * from apiinfo where cnname REGEXP '^['+#key#+']'
注:#key#,是方法中传入的值;MySQL中的SQL使用了REGEXP,是正则表达式
3、ORM工具与迁移
使用hibernate、ibatis,在数据库迁移中的不同效率
ibatis:sql需要自己写 hibernate:sql自动生成;
Hibernate的特点:Hibernate功能强大,数据库无关性好,O/R映射能力强,如果你对Hibernate相当精通,而且对Hibernate进行了适当的封装,那么你的项目整个持久层代码会相当简单,需要写的代码很少,开发速度很快。
iBATIS的特点:iBATIS入门简单,即学即用,提供了数据库查询的自动对象绑定功能,而且延续了很好的SQL使用经验,对于没有那么高的对象模型要求的项目来说,相当完美。iBATIS的缺点就是框架还是比较简陋,功能尚有缺失,虽然简化了数据绑定代码,但是整个底层数据库查询实际还是要自己写的,工作量也比较大,而且不太容易适应快速数据库修改。
易迁移行比较:对于数据库迁移来说,常用的数据库操作,如增删改查等,在hibernate中基本不需要改动;而ibatis中是自己写的针对特定数据库类型的SQL,所以需要改不少内容。
4、各数据库的不同数据类型比较及参考资料
4.1
<pre name="code" class="sql">CREATE TABLE `apiindicator` ( `id` int(11) NOT NULL, `apiid` int(11) DEFAULT NULL COMMENT '关联api信息表(apiinfo)id', `cnname` varchar(100) DEFAULT NULL COMMENT '指标中文名', `enname` varchar(60) DEFAULT NULL COMMENT '指标英文名 ', `description` varchar(1000) DEFAULT NULL, `datatype` varchar(15) DEFAULT NULL, `isout` bit DEFAULT '1' COMMENT '是否必须输出 ,默认为输出;0:不输出 1:输出', `state` int(11) DEFAULT '0', `isdelete` bit DEFAULT '0' COMMENT '删除标记:0未删除;1已删除', PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='Api指标表 ';
|
4.3
BIGINT |
NUMBER(19, |
BIT |
RAW |
BLOB |
BLOB, |
CHAR |
CHAR |
DATE |
DATE |
DATETIME |
DATE |
DECIMAL |
FLOAT |
DOUBLE |
FLOAT |
DOUBLE |
FLOAT |
ENUM |
VARCHAR2 |
FLOAT |
FLOAT |
INT |
NUMBER(10, |
INTEGER |
NUMBER(10, |
LONGBLOB |
BLOB, |
LONGTEXT |
CLOB, |
MEDIUMBLOB |
BLOB, |
MEDIUMINT |
NUMBER(7, |
MEDIUMTEXT |
CLOB, |
NUMERIC |
NUMBER |
REAL |
FLOAT |
SET |
VARCHAR2 |
SMALLINT |
NUMBER(5, |
TEXT |
VARCHAR2, |
TIME |
DATE |
TIMESTAMP |
DATE |
TINYBLOB |
RAW |
TINYINT |
NUMBER(3, |
TINYTEXT |
VARCHAR2 |
VARCHAR |
VARCHAR2, |
YEAR |
NUMBER |
4.4
Oracle |
SQL |
Mysql数据类型 |
BFILE |
VARBINARY(MAX) |
|
BLOB |
VARBINARY(MAX) |
BLOB, |
CHAR([1-2000]) |
CHAR([1-2000]) |
CHAR |
CLOB |
VARCHAR(MAX) |
TEXT, |
DATE |
DATETIME |
DATE,DATETIME, |
FLOAT |
FLOAT |
REAL, DECIMAL, |
FLOAT([1-53]) |
FLOAT([1-53]) |
|
FLOAT([54-126]) |
FLOAT |
|
INT |
NUMERIC(38) |
|
INTERVAL |
DATETIME |
|
LONG |
VARCHAR(MAX) |
|
LONG |
IMAGE |
|
NCHAR([1-1000]) |
NCHAR([1-1000]) |
|
NCLOB |
NVARCHAR(MAX) |
|
NUMBER |
FLOAT |
INT, |
NUMBER([1-38]) |
NUMERIC([1-38]) |
SMALLINT, |
NUMBER([0-38],[1-38]) |
NUMERIC([0-38],[1-38]) |
|
NVARCHAR2([1-2000]) |
NVARCHAR([1-2000]) |
SET, |
RAW([1-2000]) |
VARBINARY([1-2000]) |
BLOB,BIT, |
REAL |
FLOAT |
|
ROWID |
CHAR(18) |
|
TIMESTAMP |
DATETIME |
|
UROWID |
CHAR(18) |
|
VARCHAR2([1-4000]) |
VARCHAR([1-4000]) |
TEXT, |