急急急!!! 如何将access数据导入oracle

springzct 2008-05-30 09:58:13

现有一部分数据存储在ACCESS数据库中,并且ACCESS数据库里的数据是实时在更新的,
现在想定时把ACCESS里的数据导到ORACLE中,
因为不想牵扯到太多的数据库,所以不准备使用SQL SERVER 的DTS,
所以我想直接在ORACLE里写一个存储过程用来抽取ACCESS中的数据并保存到ORACLE里,
然后再在ORACLE里做一个作业定时调用这个存储过程.

但现在就是不知道在ORACLE里能不能通过存储过程直接连到ACCESS库?
如果能实现,最好能给个例子,说明一下如果实现,谢谢!!!
...全文
687 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
springzct 2008-06-02
  • 打赏
  • 举报
回复
谢谢大家的热心回复,
我并不想做单独的程序(delphi程序就先不考虑了),如果做单独的程序,会显得系统太乱,上线太麻烦,
所以想在ORACLE数据库中实现,
上线的时候,只要直接将数据库导给实施人员就可以了,不用实施做太多的事,少一件事就少一分出错的风险,
  • 打赏
  • 举报
回复
MS SQL7.0
jackiecheng001 2008-05-31
  • 打赏
  • 举报
回复
关注,也想这样做,
实现了从access中导入到orcale,手工的
hery2002 2008-05-31
  • 打赏
  • 举报
回复
如何实现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种方法。

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类型可以在一个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 ("jdbcracle:thin:@192.168.1.52:1521:SONIC", "sadly", "sadly";
Connection cn2 =DriverManager.getConnection ("jdbcdbc: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+"')");
}
}}
----------------------------------------------------------------
利用odbc将access数据表导入到oracle中
http://www.oracle.com.cn/viewthread.php?tid=32128&highlight=access
wxmwxmwxm 2008-05-31
  • 打赏
  • 举报
回复
我可以用DELPHI写个服务程序完成这项工作,什么时候导入,或者每隔多长时间导入用户可以自由设置
联系QQ724481678,电话13467513734
wxmwxmwxm 2008-05-31
  • 打赏
  • 举报
回复
我可以用DELPHI写个服务程序完成这项工作,什么时候导入,或者每隔多长时间导入用户可以自由设置
联系QQ724481678,电话13467513734
CathySun118 2008-05-30
  • 打赏
  • 举报
回复
Oracle Migration Workbench

17,082

社区成员

发帖
与我相关
我的任务
社区描述
Oracle开发相关技术讨论
社区管理员
  • 开发
  • Lucifer三思而后行
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧