SQL7、Sysbase、Access向Oracle8i移植方法
2007-11-11 04:43:42 来源:WEB开发网核心提示:随着Oracle(大型网站数据库平台)在中国的广泛应用,许多原来使用MS SQL7.0、Sysbase、Access等数据库的用户都碰到了数据移植的问题,SQL7、Sysbase、Access向Oracle8i移植方法, 其实,存在着许多的方法,Oracle(大型网站数据库平台)提供,
随着Oracle(大型网站数据库平台)在中国的广泛应用,许多原来使用MS SQL7.0、Sysbase、Access等数据库的用户都碰到了数据移植的问题。 其实,存在着许多的方法,这里将介绍3种方法。
1、使用MS SQL7.0自带的Import/Export工具
Import/Export工具可以方便的把数据移植到Oracle(大型网站数据库平台)。你需要通过定义ODBC For Or acle 作为目的源。这样的方法可以保证SQL7的绝大部分数据移植到Oracle(大型网站数据库平台)中去,但预先你必须在Oracle(大型网站数据库平台)建立user 和 相应的tablespace。因为SQL7中有一些特殊的datatype,如text 、image等。当一个table中有多于一个text或image的字段时,将出现错误,不能执行。这是你需要做出选择,或者把text 镜像为varchar2(4000),或者镜像为Long datatype,但long datatype一个table里只能有一个。而且,还有可能遇到字符集的问题,最好用第三种方法或者第四种。所以你遇到这样的情况,可以结合使用第3种方法。
2、使用Oracle(大型网站数据库平台) Migration Workbanch。
目前的版本是2.2,这个工具可以在http://technet.Oracle(大型网站数据库平台).com/免费下载。它是O racle提供的一个代替SQl*Loader的工具,当然目前该工具仍然不能完全取代SQL*Loade r。使用OMWB,只要你定义了ODBC for MS SQL7 或Access或Sysbase,就可以很方便的把 tabels、views、triger、procedure、shortnaps、users等完全转到Oracle(大型网站数据库平台)中去,对于 text,可以镜像为CLOB类型,CLOB类型可以在一个Oracle(大型网站数据库平台) table里有多列。 image可以镜像为BLOB。但是遗憾的是,OMWB2.2不支持中文CLOB,无论我如何调整,数据migrate 到Oracle(大型网站数据库平台)后,都变成了????,如果谁有解决的方法,别忘了email给我。我对OMWB对数据流(如image,video,sound)的控制非常的欣赏。
3、使用Oracle(大型网站数据库平台)的 SQL*Loader
使用SQL*Loader,也许是最不方便的方法,但是是最有效的方法。可以使用各种方法把源数据导到一个外部分件中。我使用了MS SQL7带的BCP工具,可以把那些特殊多te xt字段的tables导出作为外部文件。然后使用SQL*Loader在把这些数据导到Oracle(大型网站数据库平台)的一个临时表里,在对第2中方法出现的????字段进行update。
4、使用程序进行移植
1、使用MS SQL7.0自带的Import/Export工具
Import/Export工具可以方便的把数据移植到Oracle(大型网站数据库平台)。你需要通过定义ODBC For Or acle 作为目的源。这样的方法可以保证SQL7的绝大部分数据移植到Oracle(大型网站数据库平台)中去,但预先你必须在Oracle(大型网站数据库平台)建立user 和 相应的tablespace。因为SQL7中有一些特殊的datatype,如text 、image等。当一个table中有多于一个text或image的字段时,将出现错误,不能执行。这是你需要做出选择,或者把text 镜像为varchar2(4000),或者镜像为Long datatype,但long datatype一个table里只能有一个。而且,还有可能遇到字符集的问题,最好用第三种方法或者第四种。所以你遇到这样的情况,可以结合使用第3种方法。
2、使用Oracle(大型网站数据库平台) Migration Workbanch。
目前的版本是2.2,这个工具可以在http://technet.Oracle(大型网站数据库平台).com/免费下载。它是O racle提供的一个代替SQl*Loader的工具,当然目前该工具仍然不能完全取代SQL*Loade r。使用OMWB,只要你定义了ODBC for MS SQL7 或Access或Sysbase,就可以很方便的把 tabels、views、triger、procedure、shortnaps、users等完全转到Oracle(大型网站数据库平台)中去,对于 text,可以镜像为CLOB类型,CLOB类型可以在一个Oracle(大型网站数据库平台) table里有多列。 image可以镜像为BLOB。但是遗憾的是,OMWB2.2不支持中文CLOB,无论我如何调整,数据migrate 到Oracle(大型网站数据库平台)后,都变成了????,如果谁有解决的方法,别忘了email给我。我对OMWB对数据流(如image,video,sound)的控制非常的欣赏。
3、使用Oracle(大型网站数据库平台)的 SQL*Loader
使用SQL*Loader,也许是最不方便的方法,但是是最有效的方法。可以使用各种方法把源数据导到一个外部分件中。我使用了MS SQL7带的BCP工具,可以把那些特殊多te xt字段的tables导出作为外部文件。然后使用SQL*Loader在把这些数据导到Oracle(大型网站数据库平台)的一个临时表里,在对第2中方法出现的????字段进行update。
4、使用程序进行移植
例子:从SQL7.0向基于Linux下的Oracle(大型网站数据库平台)数据库倒入数据: 程序语言:java 与数据库的连接 SQL7.0:jdbc-odbc桥,java自带。 Oracle(大型网站数据库平台):jdbc,Oracle(大型网站数据库平台)提供。 代码如下:import java.lang.*;import java.sql.*;import Oracle(大型网站数据库平台).jdbc.driver.*;//倒入要用到的包public class hhw extends Object {public static void main(String args[])throws SQLException, ClassNotFoundException//抛出SQLException异常{Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");Class.forName ("Oracle(大型网站数据库平台).jdbc.driver.Oracle(大型网站数据库平台)Driver");// 登记驱动程序,准备联接数据库Connection cn1 =DriverManager.getConnection ("jdbc:Oracle(大型网站数据库平台):thin:@192.168.1.52 :1521:SONIC", "sadly", "sadly");Connection cn2 =DriverManager.getConnection ("jdbc:odbc:sql", "sa", "");//联接到数据库,建立到两个数据库的连接Statement s1=cn1.createStatement();Statement s2=cn2.createStatement();ResultSet rs1=s2.executeQuery("select * from users where id>0 and id<40000 ");//从数据源中取得数据,定义一些中间变量int id;String name=new String("1");String passwd=new String("1");String email=new String("1");//执行另一个查询,向目的数据库插入数据while(rs1.next()){id=rs1.getInt(1);name=rs1.getString("name");passwd=rs1.getString("passwd");email=rs1.getString("email");//System.out.print(id+name+passwd+email);s1.executeQuery("insert into bbsuser values('"+id+"','"+name+"','"+passwd+"','"+email+"')");}}}
- ››SQL Server 2008 R2 下如何清理数据库日志文件
- ››sqlite 存取中文的解决方法
- ››SQL2005、2008、2000 清空删除日志
- ››SQL Server 2005和SQL Server 2000数据的相互导入...
- ››sql server 2008 在安装了活动目录以后无法启动服...
- ››sqlserver 每30分自动生成一次
- ››sqlite 数据库 对 BOOL型 数据的插入处理正确用法...
- ››sql server自动生成批量执行SQL脚本的批处理
- ››sql server 2008亿万数据性能优化
- ››SQL Server 2008清空数据库日志方法
- ››sqlserver安装和简单的使用
- ››SQL Sever 2008 R2 数据库管理
更多精彩
赞助商链接