欢迎光临
我们一直在努力

ORACLE与SQL之间的数据迁移-数据库专栏,ORACLE

建站超值云服务器,限时71元/月

高级数据迁移

       很多时间,要在异构数据库之间进行数据迁移或抽取,如果在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。

图2.1 tg4msql

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如图2.1所示。

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的企业管理器。

图2.2 配置oracle的远程帐号

图2.3设置远程登录帐号

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函数可以使用,都很方便,笔记喜欢使用后者,交待一下,在数据存取方面,这四种方面效率相当。

 

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » ORACLE与SQL之间的数据迁移-数据库专栏,ORACLE
分享到: 更多 (0)

相关推荐

  • 暂无文章