动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Oracle教程 ]的信息

本月文章推荐
.用最简单的方法复制或迁移Oracle.
.Oracle & Linux--完美的组合.
.常见数据库系统之比较 Oracle数据.
.Oracle10g for AIX5L安装过程.
.怎样知道自己的机器上有哪些服务.
.ExactPapers Oracle 1Z0-501 200.
.一个生成Oracle用户密码的通用小.
.Oracle10g新增的用以简化用户管理.
.实现数据库表空间的备份或迁移.
.Oracle的一些资料.
.自己整理的OCI文档,抛砖引玉.
.Oracle数据库技术(38).
.学习总结: Oracle 的软件结构.
.Oracle环境的安全性.
.新手上路:Oracle基础工具简介.
.在Linux下安装Oracle 9i.
.Oracle数据库访问限制绕过漏洞.
.Oracle JOB 用法小结.
.轻松取得建表和索引的DDL语句.
.使用Rman的Plus archvielog选项简.

ORACLE 8i的普通连接技术的介绍

发表日期:2008-2-9 |



  
Oracle 8i的普通连接技术的介绍

====================================

欢迎大家同我交流:小白  enhydra_boy@tom.com

欢迎转载,请保留本声明,谢谢!

====================================

 

Oracle 8.1.6 中引入普通连接技术的概念(Generic connectivity),这一连接解决方案满足了对许多异种数据库存储的数据访问需求,同时并不需要安装ORACLE的透明网关(ORACLE Transparent Gateway)。该特性答应使用业界标准 ODBC 和 OLEDB 建立透明连接。

什么是普通连接(Generic connectivity)

普通连接是ORACLE的一个低端数据集成解决方案,目标是提供ORACLE 8i可以连接到非oracle数据库的能力。它的实现,是通过异种服务代理(Heterogeneous Services)来实现的。

异种服务代理的类型:
ODBC agent for Accessing ODBC data providersOLE DB agent for accessing OLE DB data providers that support SQL processing--sometimes referred to as OLE DB (SQL)ODBC agent for acceng OLE DB data providers without SQL processing support--sometimes referred to as OLE DB (FS)
普通连接的系统结构图



ORACLE客户端程序访问非ORACLE数据库的过程:客户端程序是通过SQL*NET连接ORACLE服务器,关于异种数据库的访问,交给HS代理实现。

HS代理通过下面的功能组件实现:ODBC治理器->ODBC驱动程序->数据库的网络客户端->目标数据库。

假如异种库和ORACLE数据库位于同一台服务器上,一般来说驱动程序是可以直接和本机的数据库通讯,就可以省去数据库的网络客户端这一层。

数据类型的转换

ORACLE自动实现ODBC和OLEDB数据类型到ORACLE数据类型的转换,具体的对应转换可以参考ORACLE的联机帮助http://download-west.oracle.com/docs/cd/A87860_01/doc/server.817/a76960/datatype.htm。

普通连接的限制

1          含有BLOB列的表必须要有一个主键字段;

2          BLOB/CLOB数据不直接通过pass-through的查询方式;

3          在WHERE子句中包括了函数的Updates或deletes语句不被答应;

4          不支持存储过程的调用;

HS代理(odbc/oledb)不支持分布式事务(distributed transactions),只支持单点的事务(single-site transactions)。

普通连接代理的配置

下面,我介绍一下,利用普通连接的ODBC配置。利用HS odbc代理连接SQL SERVER 2000。

第一步初始化文件的建立

首先,你必须要创建初始化文件。ORACLE提供了样例初始化文件,名字是init<agent>.ora,<agent>可能是hsodbc,hsoledb,hsolefs,分别代表了三种类型的代理,位于$ORACLE_HOME/HS/ADMIN下。

把对应的文件复制一份出来,并且改名为init<HS_SID>.ora,<HS_SID>是你SQL SERVER ODBC代理起的别名。

复制并创建了一个inithssql2k.ora文件,编辑inithssql2k.ora文件。参数有:


# This is a sample agent init file that contains the HS parameters that are

# needed for an ODBC Agent.

 

#

# HS init parameters

#

#HS_FDS_CONNECT_INFO = <odbc data_source_name>

#HS_FDS_TRACE_LEVEL = <trace_level>

HS_FDS_CONNECT_INFO = SQL2K

HS_FDS_TRACE_LEVEL = ON

HS_AUTOREGISTER = TRUE

 

#

# Environment variables required for the non-Oracle system

#

#set <envvar>=<value>


第二步 创建异种服务代理的数据字典

执行$ORACLE_HOME/rdbms/admin/caths.sql,创建相关的系统表和视图。


第三步 创建异种服务代理的工作环境

添加hssql2k的侦听服务,$ORACLE_HOME/NETWORK/ADMIN/listener.ora


SID_DESC=

     (SID_NAME=hssql2k)

       (ORACLE_HOME=d:\oracle\ora81)

      (PROGRAM=hsodbc)

    )


修改$ORACLE_HOME/NETWORK/ADMIN/tnsnames.ora,添加一个网络服务名

sql2k,将在后面创建数据库联接时用到。


sql2k =

(DESCRIPTION=

     (ADDRESS=(PROTOCOL=tcp)(HOST=localhost)(PORT=1521))

     (CONNECT_DATA=(SID=hssql2k))

     (HS=OK)

 )


重新启动侦听,并且察看服务状态


LSNRCTL for 32-bit Windows: Version 8.1.7.0.0 - ProdUCtion on 02-JUL-2003 12:49:

30

 

(c) Copyright 1998 Oracle Corporation.  All rights reserved.

 

Welcome to LSNRCTL, type "help" for information.

 

LSNRCTL> status

Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=SAM)(PORT=1521)))

STATUS of the LISTENER

------------------------

Alias                     LISTENER

Version                   TNSLSNR for 32-bit Windows: Version 8.1.7.0.0 - Produ

tion

Start Date                02-JUL-2003 11:08:31

Uptime                    0 days 1 hr. 41 min. 2 sec

Trace Level               off

Security                  OFF

SNMP                      OFF

Listener Parameter File   d:\oracle\ora81\network\admin\listener.ora

Listener Log File         d:\oracle\ora81\network\log\listener.log

Services Summary...

  ORCL          has 1 service handler(s)

  ORCL          has 3 service handler(s)

  PLSExtProc            has 1 service handler(s)

  hssql2k               has 1 service handler(s)

The command completed successfully

LSNRCTL>


Hssql2k的侦听服务已经正常运行了。


 

第四步 修改数据库启动参数文件

修改数据库启动参数文件,设置global_names=false,假如设置为true(缺省),那么数据库连接名和全局数据库名一样,这将会导致ORA-02085的错误。

 

第五步 创建访问non-oracle数据库的连接(Database Link)

   在sqlplus中,执行create database link命令。Connect to 指定了连接到SQL SERVER的用户名和密码。


 

SQL>create public database link sql2k connect to sa identified by manager using ‘sql2k’;

Database link created.

 


 

第六步 测试


Oracle8i Enterprise Edition Release 8.1.7.0.0 - Production

With the Partitioning option

JServer Release 8.1.7.0.0 - Production

 

SQL> connect scott/tiger;

Connected.

SQL> select count(*) from sysobjects@sql2k;

 

  COUNT(*)

----------

       135


 

现在,oracle已经可以访问sqlserver数据库了。以上都是,笔者参考了oracle的联机帮助,并且实际测试的经过。笔者同时也发现,采用hsodbc其实也并不是很稳定,有的sql语句会引起hsodb agent的致命错误,同时有很多限制,采用透明网关应该就可以获得很好的效果。

但是, oracle 8i的这个特性,可以不安装额外的Transparent Gateway产品。因此,只要能够满足应用的数据访问要求,采用Generic connectivity也不失为一个快速,经济的方法。

笔者的测试环境:Windows2000 Server+ORACLE 8i(8.1.7)
上一篇:ORACLE 的Virtual Private Database的全新体验 人气:572
下一篇:在DB2中如何實現Oracle的相關功能(一) 人气:433
浏览全部Oracle教程的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-10-15 自由岭峰行业专用留言系统 v1.87
2008-10-15 Tikiwiki v1.9.11 多国语言版
2008-10-15 Roclog v3.1.6.28
2008-10-15 谷秋精品课程开发系统 v2.1
2008-10-15 pageadmin企业网站管理系统 v2.1
2008-10-15 晴天免费电影系统完整版(带迅雷采
2008-10-15 PHP-B2B v2.4.0 UTF8 Beta版
2008-10-15 云峰多用户网络进销存B/S v2.1
2008-10-15 Qspace v1.1.1 Access
2008-10-16 Microsoft Office 2003 Service
2008-10-11 联系人分组工具 v1.1 中文破解版
2008-10-11 FaceMelter变脸 v2.0 汉化破解版
2008-10-11 PathTracker道路跟踪仪 v1.2 破解
2008-10-11 Rooms手机聊天室 v0.6.7 破解版
2008-10-11 RemoteDesktop远程桌面 v1.0 破解
2008-10-11 ProRemote远程调音台 v1.0.1 破解
2008-10-11 PicShare照片共享 v1.0.0 破解版
2008-10-11 Photogene照片编辑器 v1.5 汉化破
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | js/vbs加密 | md5加密 | 进制转换 | UTF-8 转换工具 | Html转换js | Html转换asp | Html转换php | Html转换perl
实用工具:汉字翻译拼音 | 拼音字典 | 符号对照表 | 个税计算 | 实时汇率查询换算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 | 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵
SEO対策 中国語教室 ホームページ作成