如何实现MS SQL 7.0、Sysbase、Access向Oracle8i移植
By Haihaier
随着Oracle在中国的广泛应用,许多原来使用MS SQL7.0、Sysbase、Access等数据库的用户都碰到了数据移植的问题。 其实,存在着许多的方法,这里将介绍3种方法。
1、使用MS SQL7.0自带的Import/Export工具
Import/Export工具可以方便的把数据移植到Oracle。你需要通过定义ODBC For Oracle 作为目的源。这样的方法可以保证SQL7的绝大部分数据移植到Oracle中去,但预先你必须在Oracle建立user 和相应的tablespace。因为SQL7中有一些特殊的datatype,如text 、image等。当一个table中有多于一个text或image的字段时,将出现错误,不能执行。这是你需要做出选择,或者把text 镜像为varchar2(4000),或者镜像为Long datatype,但long datatype一个table里只能有一个。而且,还有可能遇到字符集的问题,最好用第三种方法或者第四种。所以你遇到这样的情况,可以结合使用第3种方法。mssql2000使用DTS即可。
2、使用Oracle Migration Workbanch。
目前的版本是2.2,这个工具可以在http://technet.oracle.com/免费下载?...供的一个代替SQl*Loader 的工具,当然目前该工具仍然不能完全取代SQL*Loader。使用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工具,可以把那些特殊多text字段的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.OracleDriver");
// 登记驱动程序,准备联接数据库
Connection cn1 =DriverManager.getConnection ("jdbc困惑racle:thin:@192.168.1.52:1521:SONIC", "sadly", "sadly");
Connection cn2 =DriverManager.getConnection ("jdbc困惑dbc: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+"')");
}
}}
摘自http://oracle.cgol.net/
分享到:
相关推荐
SQL sysbase 用于提取counter
常用的数据库驱动包oracle驱动、sql server驱动+mysql +sysbase+db2 数据库驱动 jar包
主要关于Sysbase power desiger与oracle的连接
0、完全支持Mysql、SqlServer、SysBase等数据库自动生成存储过程 1、 基本完全代替编写存储过程的工作任务。 2、 让不会写存储过程的测试人员,也可顺利完成加压测试工作。 3、 让会写存储过程的测试人员,短时间内...
数据库的驱动jar包,有oracle,mysql,sql server
sybase库中导出全部表的oracle、mysql和sybase格式的建表语句
此脚本适合oracle存储过程调试用,高手直接无视!
多用途的通用数据库编程模块,支持oracle,sqlserver,sysbase等常用数据库
Sysbase数据库备份恢复步骤,关于sybase数据库备份的详细步骤。
sysbase 存储过程实例 sysbase 存储过程实例 sysbase 存储过程实例
dbvisualizer是一款非常实用的连接数据库的软件,安装简单,不像其他数据库软件那么麻烦,而且只需要配置一下,就可以连接多种数据库;本文档提供mysql oracle sqlServer 连接的驱动包和DbVisualizer 7.1.1 安装包。
利用SYBASE WEB.SQL从WWW浏览器查询SYSBASE数据库.pdf
针对sybase数据库语法与microsoft—sql语法的区别
sysbase的驱动类包
介绍了sysbase中的lib库函数,与API相结合的一些实用函数的介绍
Sysbase ASE参考手册-命令 Sysbase ASE参考手册-命令12.5
学习资料,重点介绍Sysbase ASE 12.5相关
sysbase 错误集 平时收集,sysbase 错误集 平时收集
一、 安装Sybase ASE 15.0.3客户端 5 二、 添加、修改、删除服务器条目 11 1) 添加服务器条目 11 ...4) 利用交互式SQL来操作Sybase ASE数据库 30 5) 表数据的导出与导入 32 6) 利用Sybase Central创建用户数据库 38
包括Sysbase数据库编程开发手册和管理指南两个部分~~