ODAC基础技巧(一)如何使用Net
大多数应用程序使用 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 在每一个时间关闭连接。
更多精彩尽在站长资源库电脑知识网 www.zzzyk.com