栏目分类
安装配置 | PLSQL | 备份恢复 | 性能调优 | 开发技术 | 资讯动态 | 考试认证 | 入门基础
排行榜
·如何直接解压.tar.gz文件
·Linux下的远程控制—VNC
·在VMware下配置显卡
·Linux挂载文件系统
·定时执行crontab使用方法详解
·ORACLE数据库备份方法
·PL/SQL入门教程
·Oracle存储过程返回结果集
·ORACLE数据库PROC编程经验介绍
·linux之间如何进行串口通讯
·ORACLE建库过程与操作
·oracle联机热备原理及rman增量备份原理
·如何实现数据库完整备份
·Oracle体系结构简介
·Oracle临时表使用补充
·从黑客角度检验oracle数据库
·Webmin--Linux下的用户管理工具
·mount使用指南
·利用Ghost复制您的Linux系统
·浅谈Oracle10G中的新事物:闪回恢复区

    您现在的位置: Linux宝库 >> Oracle >> 备份恢复 >> 文章正文
其他数据库向Oracle8i的转移分析
Linux宝库 收集整理  作者:Linux宝库  时间:2007-12-31  收藏本站
来自:http://doc.linuxpk.com/51450.html
联系:linuxmine#gmail.com
分类:[备份恢复]
  如何实现MS SQL 7.0、Sysbase、Access向Oracle8i移植

  随着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种方法。

  2、使用Oracle Migration Workbanch。

  目前的版本是2.2,这个工具可以在http://technet.oracle.com/免费下载。它是Oracle提供的一个代替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工具,可以把那些特殊多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: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.getStrin("passwd");

  email=rs1.getString("email");

  //System.out.print(id+name+passwd+email);

  s1.executeQuery("insert into bbsuser values('"+id+"','"+name+"','"+passwd+"','"+email+"')");

  }

  }}

  本文来自:http://doc.linuxpk.com/51450.html

 
     最新更新
·Oracle课程描述
·Oracle数据库的灾难恢复
·Oracle8i概述
·ORACLE数据库备份技术
·Oracle数据库系统使用经验六则
·在oracle中运行OS命令
·Oracledba日常管理
·ORACLE数据库的启动和关闭
·如何在两个oracle服务器之间交换数据?
·关于恢复数据库的说明
·Re:关于oracle的备份与恢复问题
·Re:紧急求救:oracle的数据导入!
·其他数据库向Oracle8i的转移分析
·Oracle8.0使用技巧
·ORACLEFORSUNSOLARIS维护手册
·在ORACLE数据库中实现从非归档模式到归档模式的转化
·UNIX平台上分布式数据库管理的经验
·Oracle8的不安全因素及几点说明
·OracleCRM解决方案
·ORACLE8的分区管理
·回滚段问题
·利用角色增强应用系统安全性
·数据库服务器的安全
·sun上oraclecluster
·手工建立ORACLE数据库步骤
·关于SELECTN问题
·rem--创建回滚段
·RedHat6.0上安装Oracle8
·如何有效地利用数据字典
·用ORACLE*Forms和ORACLE*Graphics实现数据与图形动态显示