首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 网络编程-> 数据库教程
oracle 10g + sql server 2000 透明网关设置_数据库技巧
作者:网友供稿 点击:0
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 

前提:在安装oracle时选中安装透明网关组件(默认不选中),如果未安装可以重新选择安装此组件.
环境:Oracle 10g + SQL SERVER 2000
数据库:Oracle:ZNDATA;SQL SERVER:ZNDB
目标:在oracle下建立一个tnsname用来访问SQL SERVER的ZNDB数据库.
(1)建立ZNDB数据库在Oracle下的别名zheneng:
    进入%ORACLE_HOME%\tg4msql\admin目录建立文件initzheneng.ora,里面内容如下:
    HS_FDS_CONNECT_INFO="SERVER=192.168.0.197;DATABASE=ZNDB"
    HS_FDS_TRACE_LEVEL=OFF
    HS_FDS_RECOVERY_ACCOUNT=RECOVER
    HS_FDS_RECOVERY_PWD=RECOVER
(2)建立listener:
    进入%ORACLE_HOME%\network\admin修改listener.ora文件增加:
    (SID_DESC =
          (SID_NAME = zheneng)   ###注意:要与前面建的文件名字initzheneng去掉init后一样.
          (ORACLE_HOME = D:\oracle\product\10.1.0\db_1)
          (PROGRAM = tg4msql)
        )
(3)建立tnsnames.ora:
    与(2)相同目录下修改tnsnames.ora文件增加一个TNSNAME:
    ZNDB =
      (DESCRIPTION =
        (ADDRESS_LIST =
          (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.197)(PORT = 1521))
        )
        (CONNECT_DATA =
          (SID = zheneng)
        )
        (HS = zheneng)
      )
(4)sqlplus测试:
    创建数据库连接:
    sql>create   database   link   mssqlLink   connect   to   sa   identified   by   sa using ZNDB;
    sql>select * from akm@mssqlLink
    如果正确的话应该显示sqlserver中的结果

参考网上文章:
不同数据库平台的互连一般称之为数据库的异构服务,现在各大数据库之间都可以实现这样的异构互连,只是各厂商的具体实现技术不一样,如:在SQL   SERVER里面叫做LINKED   SERVER,通过ODBC实现与其它数据库的互联。   
  而ORACLE实现异构服务的技术叫做透明网关(Transparent   Gateway),当然之前ORACLE还采用过通用连接技术。目前ORACLE利用透明网关可以实现和SQL   SERVER、SYBASE、DB2等多种数据库的互联。 
  
  透明网关的体系结构也很简单,在ORACLE和SQL   SERVER之间使用ORACLE透明网关服务器实现互连互通,其中透明网关服务器可以与ORACLE或SQL   SERVER数据库在同一台主机上,也可以是在独立的一台主机上。 
  
  下面是具体步骤,如有疑问欢迎和我联系,MSN:   gototop_ncn@hotmail.com。 
  
  1、在SQL   SERVER数据库上创建测试账号和表 
  
  这里我用的是10.16.74.140的PUBS数据库,账号cyx, 
  
  create   table   t   (c   char(10)); 
  
  2、我测试所用数据库和透明网关是在同一台机器上,在我本机:10.16.98.16,透明网关在oracle默认安装时是不安装的,所以如果你想用需要选择这一选项。 
  
  3、安装透明网关for   sql   server的软件后,可以在$ORACLE_HOME下看到tg4msql目录,编辑$ORACLE_HOME/tg4msql/admin/inittg4msql.sql文件确认这一行正确: 
  
  HS_FDS_CONNECT_INFO="SERVER=10.16.74.140;DATABASE=pubs" 
  
  4、修改透明网关server上的listener.ora,在SID_LIST中加入以下内容: 
  
  (SID_NAME   =   tg4msql)   #   SID自己命名   
  
  (ORACLE_HOME   =   c:)   
  
  (PROGRAM   =   tg4msql)   
  
  5、在oracle   server上的tnsnames.ora中加入到透明网关的tnsname,内容如下: 
  
  sql2k   =   
  
  (DESCRIPTION   =   
  
  (ADDRESS_LIST   =   
  
  (ADDRESS   =   (PROTOCOL   =   TCP)(HOST   =   10.16.98.16)(PORT   =   1521))   #此处HOST填的是透明网关SERVER的地址 
  
  )   
  
  (CONNECT_DATA   =   (SID   =   tg4msql)   )   #此SID应和透明网关SERVER上设定的SID相同 
  
  (HS=OK)   
  
  )   
  
  6、修改ORACLE   SERVER的初始化参数,将global_names设为false,因为我们并不使用GLOBAL   NAME。然后重起数据库。 
  
  7、现在在ORACLE   SERVER上创建DB   LINK就可以了。下面实验数据: 
  
  ------------   www.ncn.cn   -------------   gototop   -------------- 
  
  C:>sqlplus   /nolog 
  
  SQL*Plus:   Release   9.2.0.1.0   -   Production   on   星期三   6月   25   13:29:41   2003 
  
  Copyright   (c)   1982,   2002,   Oracle   Corporation.   All   rights   reserved. 
  
  SQL>   conn   sys/change_on_install   as   sysdba 
  
  已连接。 
  
  SQL>   create   user   cyx   identified   by   cyx   default   tablespace   users; 
  
  用户已创建 
  
  SQL>   grant   connect   to   cyx; 
  
  授权成功。 
  
  SQL>   grant   resource   to   cyx; 
  
  授权成功。 
  
  SQL>   conn   cyx/cyx 
  
  已连接。 
  
  SQL>   create   database   link   tosql2k   connect   to   cyx   identified   by   cyx   using   
  
  2   sql2k; 
  
  数据库链接已创建。 
  
  SQL>   select   *   from   t@tosql2k
  
  c 
  
  ---------- 
  
  abc 
  
  aaa 
  
  bbb 
  
  cyx 
  
  gototop 
  
  ncn 
  
  11111 
  
  已选择7行。 
  
  SQL>   insert   into   t@tosql2k   values(ncn.cn); 
  
  已创建   1   行。 
  
  SQL>   commit; 
  
  提交完成。 
  
  SQL>   select   *   from   t@tosql2k
  
  c 
  
  ---------- 
  
  abc 
  
  aaa 
  
  bbb 
  
  cyx 
  
  gototop 
  
  ncn 
  
  11111 
  
  ncn.cn 
  
  已选择8行。 
  
  ------------   www.ncn.cn   -------------   gototop   -------------- 
  
  以上示例,oracle   server和透明网关server都是在同一台机器上,像在开始说明的那样,我们同样可以在其他下面oracle   server中通过透明网关来访问sql   server的数据。下面是示例: 
  
  现在这个oracle   server上添加tnsname。 
  
  ------------   www.ncn.cn   -------------   gototop   -------------- 
  
  hawk3$sqlplus   cyx 
  
  SQL*Plus:   Release   8.1.7.0.0   -   Production   on   Wed   Jun   25   14:00:34   2003 
  
  (c)   Copyright   2000   Oracle   Corporation.   All   rights   reserved. 
  
  Enter   password: 
  
  Connected   to: 
  
  Oracle8i   Enterprise   Edition   Release   8.1.7.0.0   -   Production 
  
  With   the   Partitioning   option 
  
  JServer   Release   8.1.7.0.0   -   Production 
  
  SQL>   create   database   link   hawk3_sql2k   connect   to   cyx   identified   by   cyx 
  
  2   using   sql2k; 
  
  Database   link   created. 
  
  SQL>   select   *   from   t@hawk3_sql2k
  
  c 
  
  -------------------- 
  
  abc 
  
  aaa 
  
  bbb 
  
  cyx 
  
  gototop 
  
  ncn 
  
  11111 
  
  ncn.cn 
  
  8   rows   selected. 
  
  ------------   www.ncn.cn   -------------   gototop   -------------- 
  
  gototop   2003.7.25注:很多朋友问到关于透明网关的一些问题,在此加以说明如下: 
  
  1、Oracle   For   SQL   Server的透明网关在UNIX下无法实现,目前只支持WIN;   原因很简单,SQL   Server本身不支持UNIX,所以Oracle也无法直接在UNIX下访问SQL   Server。 
  
  2、Oracle   For其它数据库的透明网关,如SYBASE等有UNIX本版本的数据库在UNIX可以实现。   
  
  3、Oracle透明网关软件在Oracle   8i时是需要花钱另买的,大约1万$;到Oracle   9i时是作为数据库的一个组件免费发布的。安装时在组件种选择即可。   
  
  4、针对我们的实际应用,如果有需要实现Oracle   到SQL   Server的互连,我们需要另外用一台WIN下的Oracle   9i来做透明网关服务器,其它UNIX下的Oracle通过这个透明网关来访问SQL   Server。   
  
  5、不同数据库间的数据处理需使用标准SQL来实现。   
  
  6、各数据库中特殊的数据类型,需要在程序中实现转换,应尽量避免使用无法转换的数据类型。


文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·jsp留言板源代码4-JSP教程,数据库相关
·“脱衣秀”泛滥 四川打击淫秽色情视频聊天室
·c#中使用 crystal reports (水晶报表)的打包和部署问题-.NET教程,报表/图形/Office
·MDAC2.8 下载!-ASP教程,数据库相关
·数据库安装包的制作(参考MSDN)-.NET教程,安装和部署
·asp讲座之七:asp与数据库(二)
·深度和广度优先分油问题(C#实现)-.NET教程,C#语言
·C#在状态栏中,自绘进度条,-.NET教程,C#语言
·怎么清除sql server日志
·C#中的接口-.NET教程,C#语言
最新文章
·sql server 2005 ce基础概要_数据库教程
·用flash as代码制作按钮弹出窗口_flash教程
·alexa:戏曲性地调整_alexa排名
·google也推出域名注册_google推广
·技巧总结:div中class与id的区别及应用_css教程
·windows vista命令runas.exe全解析_windows vista
·photoshop将美女照片处理成仿古斑驳油画_photoshop教程
·百度主题推广代码的完全解析-知己知彼_网赚技巧
·你的google adsense帐号是否被人盗用?_网赚技巧
·如何挑出google adsense中单价极低的广告商_网赚技巧
相关主题
  • oracle rac 10.2 的在 linux 上的存储选项_数据库技巧
  • oracle sql精妙sql语句讲解_数据库技巧
  • oracle 10g 安装中一些问题解决_数据库技巧
  • oracle 存储过程的基本语法_数据库技巧
  • oracle数据库文件中的导入\导出(imp/exp命令)_数据库技巧
  • 西部数码虚拟主机

    友情链接
    CNNIC 西部数码
    万网 自助建站
    虚拟主机 asp空间
    域名注册 域名
    域名申请 主页空间
    论坛空间 网站空间
    国际域名 虚拟空间
    空间租用 DDOS防火墙
    成都主机托管 四川主机托管
    主机租用 服务器租用
    网站目录 自助建站
    虚拟主机 网址大全
    软件下载
    自助链接
    虚拟主机资讯 特价虚拟主机
    版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
    关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
    特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
    发表评论 打印  刷新     关闭