设为首页
加入收藏夹

MSSQL7.0SysbaseAccess向Oracle8i移植
浏览选项:

  随着Oracle在中国的广泛应用,许多原来使用MS SQL7.0、Sysbase、Access等数 据库的
用户都碰到了数据移植的问题。其实,存在着许多的方法,这里将介绍3 种方法。
 1、使用MS SQL7.0自带的Import/Export工具 Import/Export工具可以方便的把数据
移植到Oracle。你需要通过定义ODBC For Oracle 作为目的源。这样的方法可以保证SQL7的绝
大部分数据移植到Oracl e中去,但预先你必须在Oracle建立user 和 相应的tablespace。因
为SQL7中有 一 些特殊的datatype,如text 、image等。当一个table中有多于一个text或
image 的字段时,将出现错误,不能执行。这是你需要做出选择,或者把text 镜像为v
archar2(4000),或者镜像为Long datatype,但long datatype一个table里只能 有一个。而
且,还有可能遇到字符集的问题,最好用第三种方法或者第四种。所以你遇到这样的情况,可
 2、使用Oracle Migration Workbanch。 目前的版本是2.2,这个工具可以在
http://technet.oracle.com免费下载。 它是Oracle提供的一个代替SQl*Loader的工具,当然
目前该工具仍然不能完全取 代SQL*Loader。使用OMWB,只要你定义了ODBC for MS SQL7 或
Access或Sysbase ,就可以很方便的把tabels、views、triger、procedure、shortnaps、
users等完全转到Oracle中去,对于text,可以镜像为CLOB类型,CLOB类型可以在一个Or
acle 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.forNam
 Class.forName ("oracle.jdbc.driver.OracleDriver"); // 登记驱动程序,准备联
  Connection cn1 =DriverManager.getConnection"jdbc:oracle:thin:@19
 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<4 0000 "); //从数据源中取得数据,定义一些中间变量
  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+",\"+pas
swd+",\"+email+")"); } }}



Copyright © 2004 wanxu.com All Rights Reserved