首页 > 数据库 > Oracle > 正文

ORACLE与SQL之间的数据迁移

2024-08-29 13:31:07
字体:
来源:转载
供稿:网友

高级数据迁移

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

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

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

 

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表