Oracle 与SQL Server 数据库之间的交互

     一.使用 Oracle 透明网关从oracle 端连Sql Server 数据库

 

Step1  安装oracle 透明网关

 

Condition: 连Sql server 的网关的操作系统必须是window ,因为在网关上还必须得装一个sql sever 的客户端,用于监听sql server 服务器发来的消息。

      安装透明网关组件的软件在oracle 安装盘里面,不需要另行下载。

 

安装方法与步骤:  

1.启动安装程序以后,选择安装类型为定制

 

 

2.选择 oracle transparent gateways for Miscrosoft Sql Server ,然后点击下一步,装完即可。

 

 

Step 2  安装sql server 客户端(这一步不再演示)

 

 

 

Step 3  配置透明网关与Oracle 服务器

1.       修改ORACLE_HOME/tg4msql/admin下的inittg4msql.ora 文件,配置好参数

其中HS_FDS_CONNECT_INFO=jysc.msdb的jisc代表sql server 的服务名,msdb是需要连接的数据库。

 

 

   

 

2           配置oracle 服务器的listener

修改listener.ora 文件,添加以下参数,作用是使监听器能够监听网关发过来的信息

 (SID_DESC =

      (PROGRAM = tg4msql)

      (ORACLE_HOME = D:/OraHome_1)

      (SID_NAME = tg4msql)

)

其中SID_NAME 可以自己取名。

 

3           配置网络服务名tnsname

LKSQL =

  (DESCRIPTION =

    (ADDRESS_LIST =

      (ADDRESS = (PROTOCOL = TCP)(HOST = xuchunyang)(PORT = 1521))

    )

    (CONNECT_DATA =

      (SID = tg4msql)

    )

    (HS = OK)

  )

 

这里的HOST=xuchunyang ,xuchunyang 是透明网关服务器的服务器名,也可以是主机IP 地址 ,(SID = tg4msql) 的tg4msql不是固定名,需跟上面listener SID_NAME 一致。

 

 

   

  一切配置都已经完毕,然后可以创建database link 去连接sql server 数据库了

 

 

      

 Step 4 创建database link

 

 连上oracle 数据库,运行下面的语句,创建database link

 

create database link LKTOSQL
  connect to XuChunYang identified by garyxu0120
  using 'LKSQL';

 

 

这里 using 'LKSQL'的LKSQL 是网络服务名,跟开始配置的tns name 一致。

 

 

现在,我们就可以使用database link 去访问sql server 数据库的数据了。例如,运行

Select * from sysobjects@LKTOSQL where rownum <10

 

 

 

建立好链接后,使用trigger 可以使两种不同数据库之间的表数据同步。
 

 

 

二 使用Sql Server 链接服务器从Sql server 连oracle 数据库

 

1.要求pc机上安装oralce客户端软件和sqlserver软件。  
   

 2.客户端的配置tnsnames.ora文件,配置所要连接的数据库服务器(windows,unix等平台均可以)

 
  GARYXU =

  (DESCRIPTION =

    (ADDRESS_LIST =

      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.67)(PORT = 1521))

    )

    (CONNECT_DATA =

      (SERVICE_NAME = GARY)

    )

  )

3.配置windows的ODBC数据源:  
      开始菜单—》设置—》管理工具—》数据源(ODBC)—》进入配置用户DSN或者系统DSN均可以:添加—》选择Microsoft   ODBC   for   oracle  —— 》自定义数据源名称(最好跟tns中连接串同名!)—》服务器名称(必填!填写tns文件中的连接串名称)—》完成。   

 


   
  4.配置sqlserver2000中的连接服务器:  
      企业管理器—》安全性—》连接服务器—》右键新建连接服务器—》定义连接名称;   选其他数据源;   指定程序名称为:Microsoft   OLE   DB 
    Provider   for   Oracle;     产品名称可不填;   数据源指定刚才ODBC中定义好的数据源名称;   提供程序字符串按以下格式填写:

User =username;Password=userpasswd(或者按如下格式:UID=username;PWD=userpasswd),这里的用户名和密码对应所要连接的oracle数据库中用户名和密码   —》   安全性标签页里:设置用此安全上下文进行,并录入oracle的数据库用户名和密码—》服务器选项标签页可默认—》确定。  
   
  5.准备工作全部完成!在sqlserver企业管理器—》安全性—》连接服务器打开刚建好的连接服务器—》点击表,即可在右边窗口看到该oracle数据库用户拥有的的所有表名,但在这里还并不能查看表的记录,这个需要在sqserver的查询分析器中用具体sql实现!访问表时,使用格式为:    

 [连接服务器名]..[ORACLE用户].[表名]。更详细具体的使用这里不再赘述。

 

 

同样,建立好链接后,使用trigger 可以使两种不同数据库之间的表数据同步。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值