[转]ODAC 应用技巧 (一)使用 ODAC 的 Net 方式

摘要:
原文地址:ODAC应用技巧(一)使用ODAC的Net方式使用ODAC的Net方式nxyc_twz@163.com大多数应用程序使用OCI的ODAC标准方式来连接Oracle数据库服务器。运行使用ODACNet的应用程序,仅需要有一个支持TCP/IP协议的操作系统。使用Net选项在安全方面,与使用OCI的Oracle的加密方式并不相同。ODACNet选项的限制:仅支持通过TCP/IP协议来连接Oracle;不支持Oracle8的对象,数组;不支持TOraLoader的直接装载;请注意:我们并不能保证ODACNet可以在所有网络上的所有Oracle服务器上运行。

原文地址:ODAC 应用技巧 (一)使用 ODAC 的 Net 方式

使用 ODAC 的 Net 方式

nxyc_twz@163.com

大多数应用程序使用 OCI 的ODAC 标准方式来连接 Oracle 数据库服务器。这是使用第三方开发语言设计 Oracle 应用程序最常用的方法。 所有的 OCI 接口都作为内部库来使用,使得编译生成的应用程序非常小。但是,这需要在客户机上安装 Oracle 客户端软件,这使得安装和管理要花费额外的开销。 有时,安装 Oracle 客户端程序甚至是不可能的。 例如,如果你需要在远程计算机上设置你的应用程序,你不能提供特殊的文件支持。

ODAC Net 允许你的应用程序直接通过 TCP/IP 协议来连接 Oracle,而不需要 Oracle 客户端软件。运行使用 ODAC Net 的应用程序,仅需要有一个支持 TCP/IP 协议的操作系统。
使用 ODAC Net 连接 Oracle 服务器,你需要知道 Oracle 服务器的地址,监听端口号以及数据库实例名称。
在你的应用程序中使用 Net 选项前,你只需要设置 TOraSession 对象的选项 Net 为 True 且指定它的Server 属性为指定的数据库。如果使用 ODAC 的标准方式通过 OCI 来连接数据库,你必须设置 Server 属性为 TNS 别名,但现在使用 ODAC 的 Net 选项,你只需要指定数据库字符串,格式如下: Host:Port:SID.

这里, Host 指服务器地址, Port 指服务器监听端口号, SID 指特定的系统实例名称。

这里有个例子示范不使用 OCI 而 连接数据库:

var
Session: TOraSession;
. . .
Session.Options.Net := True;
Session.Username := 'Scott';
Session.Password := 'tiger';
Session.Server := '205.227.44.44:1521:orcl';
Session.Connect;

注意:这些是你的应用程序要支持 Net 选项时所必须的。你不需要重写应用程序的其它部分。除此之外,你还可以在任何时候通过 OCI 连接 Oracle 。要实现它,你仅需要设置 TOraSession.Options.Net 选项为 False.

OCI 与 Net:

使用 ODAC 标准方式和 Net 方式编译的应用程序,在程序大小和运行速度上非常相似。使用 Net 选项在安全方面,与使用 OCI 的 Oracle 的加密方式并不相同。 Net 使用 DES 来验证安全性,现在它并不支持 Oracle 的加密方式。

ODAC Net 的优势:

- 不需要安装和管理 Oracle 客户端软件;
- 减少系统需求。

ODAC Net 选项的限制:

仅支持通过 TCP/IP 协议来连接 Oracle;
不支持 Oracle 8 的对象,数组;
不支持 TOraLoader 的直接装载;
请注意:我们并不能保证 ODAC Net 可以在所有网络上的所有 Oracle 服务器上运行。我们使用 Net 选项在本地局域网上测试了 Windows 平台上 Oracle 7.3 以后的所有版本。
ODAC 通过 OCI 可以运行在所有的 Oracle 服务器上。Net 选项在 Window 及 Linux 平台上的所有Oracle 服务器上被测试过。我们不能保证它可以运行在其它平台上。

使用防火墙时可能会出现验证问题。
Net 选项在本地语言下运行时会有些不同。它不支持客户端的 NLS 转换。
BreakExec 过程不能运行。
TOraLoader 组件不在运行在直接路径接口模式(lmDirect 模式)。

Net 选项还有一些其它问题。例如,进行截断日期比较时会出现错误。

SELECT * FROM scott.emp WHERE hiredate >= TRUNC(:hiredate)

执行该查询时会出现 ORA-00932 错误: 不支持的数据类型。

如果没有上面的限制,你可以通过 OCI 在任何时间关闭连接。

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/nxyc_twz/archive/2003/02/15/16060.aspx

--

使用ODAC方式最大的好处在于可以不用在系统运行的机器上部署Oracle客户端,不过此方式与客户端方式相比有一定限制,使用时需注意。详细信息可参考nxyc_twz的博客。

免责声明:文章转载自《[转]ODAC 应用技巧 (一)使用 ODAC 的 Net 方式》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇信息熵Eclipse debug 多线程下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

MySQL体系结构以及各种文件类型学习

1,mysql体系结构 由数据库和数据库实例组成,是单进场多线程架构。 数据库:物理操作系统文件或者其它文件的集合,在mysql中,数据库文件可以是frm、myd、myi、ibd等结尾的文件,当使用ndb存储引擎时候,不是os文件,是存放于内存中的文件。 数据库实例:由数据库后台进程/线程以及一个共享内存区组成,共享内存可以被运行的后台进程/线程所共享。...

mysql 数据库的表中复制一条数据并添加到该表中

数据库的表中复制一条数据并添加到该表中: 需求: 复制一行数据,并把c_name=化学,tid=015  1、准备sql查询语句:介绍一种快速生成的查询语句  2、编写sql语句:    INSERT INTO `course`(SELECT `cid` + 1, '015', '化学', `ctype`, `ccredit`, `cmax`, `c...

oracle的存储过程语法(转)

1、ORA-00942: table or view does not exist 指的你要操作的表尚未存在,需要先create出来先。 2、ORA-00922: missing or invalid option 指的是有语法错误。遗漏了分号什么的 3、Warning: Procedure created with compilation errors...

lnmp+phpmyadmin配置与出现问题

本博客归moka同学(新浪微博:moka同学)本人亲自整理,如有使用,请加链接注明出处。 lnmp 安装完全后,配置phpmyadmin .其访问方式为 http://202.18.400.379/phpmyadmin 一、把phpmyadmin放到web根目录下面      提示:最好更改文件名成为其他,以防被人破解 二、配置在phpmyadmin文件下...

DEP(数据执行保护)介绍

DEP - 数据执行保护的缩写,Data Execution Prevention。 数据执行保护 (DEP) 是一套软硬件技术,能够在内存上执行额外检查以帮助防止在系统上运行恶意代码。在 Microsoft Windows XP Service Pack 2、 Microsoft Windows Server 2003 Service Pack 1...

SCSF智能客户端学习笔记(一)

什么是智能客户端   要了解智能客户端,首先要认识瘦客户端技术和胖客户端技术各自的优缺点。        对于前者,典型的应用就是使用浏览器,通过输入URL远程访问服务端,并向服务端发送命令,获取服务端的资源,然后在客户端的浏览器上显示出来。由于这种技术数据库存放在服务端,客户端应用界面的也是由服务端的文件生成,因此在客户端上占用资源少,对客户端的设备要求...