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

高级数据迁移

很多时间,要在异构数据库之间进行数据迁移或抽取,如果在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
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值