学院首页 软件应用 编程开发 创意设计 认证培训 软件论坛
ASP ASP.NET PHP JSP SQL MYSQL Java VB

您的位置:学院 >> 编程开发 >> Oracle >> Oracle与SQL Server之间的数据迁移


Oracle与SQL Server之间的数据迁移


很多时间,要在异构数据库之间进行数据迁移或抽取,如果在SQL中提取ORACLE的数据,可以通过ODBC、OLEDB等多种方式,要从ORACLE提取SQL中的数据,大都是通过透明网关来实现的。

在异构数据抽取过程中,最好采用SQL92标准的语法编写SQL代码,同时要注意不同数据库之间数据类型的转换关系,如ORACLE的日期类型用DATE、SQL用Datetime等。

一 关于ORACLE的透明网关配置

ORACLE安装时(9i),将TRANSPARENT GATEWAY FOR MSSQL选中,在ORACLE主目录\BIN中,有个tg4msql.exe程序,它是透明网关程序啦,同时在主目录中还有tgrmsql的一个目录,ORACLE_HOME\tg4msql\admin目录中的inittg4msql.ora就是需要进行配置才能在ORACLE中连接SQL。

1 如何配置透明网关呢?打开inittg4msql.ora:

  
  # HS init parameters
  

xzh代表SQL服务名,pubs代表要访问的SQL数据库。

  
  HS_FDS_CONNECT_INFO="SERVER=xzh;DATABASE=pubs"
  
  HS_FDS_TRACE_LEVEL=OFF
  
  HS_FDS_RECOVERY_ACCOUNT=RECOVER
  
  HS_FDS_RECOVERY_PWD=RECOVER
  

2 监听的配置oracle_home\network\admin\Listiner.ora

  
  LISTENER =
  
   (DESCRIPTION_LIST =
  
    (DESCRIPTION =
  
     (ADDRESS_LIST =
  
      (ADDRESS = (PROTOCOL = TCP)(HOST = xzh)(PORT = 1521))
  
     )
  
     (ADDRESS_LIST =
  
      (ADDRESS = (PROTOCOL = TCP)(HOST = xzh)(PORT = 1527))
  
     )
  
    )
  
   )
  
  SID_LIST_LISTENER =
  
   (SID_LIST =
  
    (SID_DESC =
  
     (GLOBAL_DBNAME = xzh.world)
  
     (ORACLE_HOME = D:\oracle\ora92)
  
     (SID_NAME = xzh)
  
    )
  
    (SID_DESC = 
  
      (GLOBAL_DBNAME = tg4msql) 
  
      (PROGRAM = tg4msql) 
  
      (SID_NAME = tg4msql)
  
      (ORACLE_HOME = D:\oracle\ora92)
  
    )
  
   )
  

加亮代码是要在监听文件中新加部分,GLOBAL_DBNAME、SID_NAME可以任意,PROGRM必须指向tg4msql。

3 本地服务文件的配置oracle_home\network\admin\TnsNames.ora

  
  XZH =
  
   (DESCRIPTION =
  
    (ADDRESS_LIST =
  
     (ADDRESS = (PROTOCOL = TCP)(HOST = xzh)(PORT = 1521))
  
    )
  
    (CONNECT_DATA =
  
     (SERVER = DEDICATED)
  
     (SERVICE_NAME = xzh.world)
  
    )
  
   )
  
  TG4MSQL =
  
   (DESCRIPTION =
  
    (ADDRESS_LIST =
  
     (ADDRESS = (PROTOCOL = TCP)(HOST = xzh)(PORT = 1527))
  
    )
  
    (CONNECT_DATA =
  
     (SID = tg4msql)
  
    )
  
    (HS = OK)
  
   )
 

 







使用SQL的本地服务名为TG4MSQL,可以任意写,SID必须是Listiner.ora中指定的那个SID_NAME,PORT也必须是监听中指定的PORT,主机等都要符合一致。 到此为止,我们把透明网关大致已经配置好啦,如果要访问SQL,还要使用数据库链才方便。

4 在SQL中创建登录帐号xzh口令xzh,使用可以访问PUBS数据库。

  
  CREATE DATABASE LINK sql CONNECT TO xzh IDENTIFIED BY xzh
  
  USING ‘TG4MSQL’
  

这里的USING ‘TG4MSQL’是tnsnames.ora中配置好的本地服务名,sql是我们以后要引用的数据库链名。

  
  SQL>SELECT * FROM sales@sql
  

如果有数据返回,表示我们访问SQL数据库的通道已经建成,请大胆使用吧,但对远程异构数据库不充许进行DDL操作。

  
  SQL>CREATE TABLE all_users@tg4msql FRIN all_users;
  

ERROR 位于第 1 行。ORA-02021: 不允许对远程数据库进行 DDL 操作。

二 SQL访问ORACLE的方法

1 通过行集函数OPENDATASOURCE

  
      OPENDATASOURCE ( provider_name, init_string )
  
    SELECT *
  
  FROM OPENDATASOURCE(
  
       'MSDAORA',
  
       'Data Source=xzh.oracle;User ID=POS;Password=POS')..POS.A0325

MSDAORA是OLEDB FOR ORACLE的驱动,初始化字符串指定本地服务名、用户名、口令。然后引用表中数据时要以服务器..用户名.表名。注意一定是四部分组成,用户名与表名一定要大写。

  
      SELECT * INTO PUBS.DBO.A0325 FROM 
  
  OPENDATASOURCE(
  
       'MSDAORA',
  
       'Data Source=xzh.oracle;User ID=POS;Password=POS' )..POS.A0325
  

将ORACLE中POS模式的A0325导入SQL的PUBS数据库。

2 通过SQL的链接服务器引用ORACLE的数据

查看已经存在的链接服务器:

  
    SELECT*FROM SYSSERVERS
  

添加链接服务器到SQL:

  
    EXEC SP_ADDLINKEDSERVER
  
    @server = 'ORCL',  ORCL是SQL中链接服务器名称
  
    @srvproduct = 'Oracle',  Oracle    固定的            
  
    @provider = 'MSDAORA',  MSDAORA  固定的
  
    @datasrc = 'xzh.oracle' DataSrc   本地服务名
  
    EXEC SP_DROPSERVER ‘ORCL’删除链接服务器
  

在这里声明一下,如果现在就访问ORACLE肯定不能,因为没有提供登录ORACLE的用户名/口令EXEC SP_ADDLINKEDSRVLOGIN 'ORCL', false, 'sa', 'POS', 'POS'Sa是SQL本地登录帐号,POS/POS是ORACLE的登录帐号,但这句话对我们要达到的目的没有帮助。

  
  SELECT * FROM ORCL..POS.A0325
  

还是四部分组成,注意事项同上,为什么不行呢,本人一直在寻找解决办法,最后发现通过SQL语句没法解决,只有打开SQL的企业管理器。

  
  SELECT * FROM ORCL..POS.A0325  --这次终于OK。
  
  SELECT * FROM OPENQUERY(ORCL, 'SELECT * FROM POS.A0325')
  

3 使用SQL的OPENROWSET函数

  SELECT a.*
  
  FROM OPENROWSET('MSDAORA',
  
 'xzh.oracle';'POS';'POS', POS.A0325) AS a ORDER BY a.ID
  

有些地方要用别名才能引用,请大家注意。

4使用ODBC的方式

  SELECT A.*
  
  FROM OPENROWSET('MSDASQL','ORCL_ODBC';'POS';'POS',
  
    POS.A0325) AS A
  
  ORDER BY A.ID
  

ORCL_ODBC是ORACLE的ODBC数据源,创建ODBC不用我说吧,以上所有代码在SQL QUERY ANALYZE 中通过。

三 总结

关于SQL访问ORACLE有四种方式,其中通过ODBC与链接服务器的方式做起来难度较大,对手新手会麻烦一些,使用OLE DB FOR ORACL驱动时,有OPENDATASOURCE与OPENROWSET函数可以使用,都很方便,笔记喜欢使用后者,交待一下,在数据存取方面,这四种方面效率相当。

技术文章快速查找

栏目导航
软件应用
·操作系统 ·杀毒防黑 ·应用软件
·聊天软件 ·网络软件  
Web开发
·ASP ·JavaScript ·CGI
·JSP ·VbScript ·Web服务器
·PHP ·XML  
开发语言
·VB ·VC ·ASP.NET
·Java ·C/C++ ·Delphi
数据库开发
·MySQL ·SQL/Access ·PowerBuilder
·Oracle ·DB2  
网站设计
·Flash ·Dreamweaver ·HTML/CSS
·Fireworks ·FrontPage  
平面设计
·Photoshop ·CorelDraw ·AutoCAD
·FreeHand ·Illustrator ·3DsMAX
媒体动画
·Director ·Authorware ·Maya
·视频处理    


相关软件 产品库推荐
·笔记本 ·台式机 ·服务器
·数码相机 ·手机 ·GPS
·DV摄像机 ·MP3 ·MP4
·CPU ·硬盘 ·内存
·主板 ·显卡 ·显示器
·打印机 ·投影机 ·路由器

还没人留言,抢个先,哈哈!
对"Oracle与SQL Server之间的数据迁移"的评论 - 快速回贴
内容:
  [完成后可按Ctrl+Enter发布]

百度中 Oracle与SQL Server之间的数据迁移 相关内容
Google搜索中 Oracle与SQL Server之间的数据迁移 相关内容
雅虎中 Oracle与SQL Server之间的数据迁移 相关内容
Sogou搜索中 Oracle与SQL Server之间的数据迁移 相关内容

相关软件 最新回复帖子:

·Windows Vista 中卸载软件的不同方式
·没有mysql支持时的替代方案
·一个可以发送附件及HTML格式邮件的PHP类
·AutoCAD打造精致三维鸟笼实例详解
·Photoshop自定义水晶字特效样式
·AutoCAD三维基础实例教程
·PS为黑背景长发美女照片抠图换背
·用Photoshop自制个性摩托车贴花小经验
·轻松几步将美女照片处理为手工素描
·巧用Photoshop画笔轻松绘制创意特效


  相关软件 Oracle与SQL Server之间的数据迁移相关文章
提高Oracle数据库系统Import的性能 Delphi中BDE直连方式访问Oracle的问题
Oracle互联网文件系统达到信息共享 Oracle数据库磁盘输入输出性能和优化
用Oracle数据库的WEB服务制作网页 Java开发使用Oracle数据库的注意事项
Oracle 9i在AIX上的性能调整--内存篇 Oracle许可执行安全模式更好实现控制
Oracle Spatial临时表具体设计及功能 可预见的Oracle应用程序的性能调优
Oracle数据库设计开发阶段性能优化 浅谈Oracle数据库的建模与具体设计
Oracle大文本在ASP中存取问题的解决 用.NET调用oracle存储过程返回记录集
连接Oracle数据库及故障解决办法介绍 Oracle数据库中索引树的结构与块尺寸
在Oracle数据库中连接异种数据源 管理Oracle OLAP时清除通往OLAP的障碍
Oracle9i新特性之数据库监控系列详解 在Oracle/2000中调用Windows API函数