原文地址: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 方式相关推荐

  1. latex 表格单元格上下左右居中_Excel文字对齐技巧:学会这6种方式,快速整理规范表格...

    [温馨提示]亲爱的朋友,阅读之前请您点击[关注],您的支持将是我最大的动力! Excel制作表格中,文字在单元格内对齐的方式,我们经常用到的有居中对齐.居右对齐.居左对齐,对过这些对齐方式,可以编辑出 ...

  2. 调试技巧:如何以数组的方式查看一个指针

    对于下面两个变量: int *p = new int[10]; int q[10]; 在watch窗口中查看有不同的效果,查看p的时候可以看到一个地址,展开+号只能看p[0]的值:查看q的时候也可以看 ...

  3. 使用技巧之清洁Mac 的正确方式

    如何清洁 MacBook 或是 iMac,使用酒精会不会影响到产品的镀膜,怎么做才是正确的Mac清洁方式,跟着小编来看看清洁方法吧! 清洁Mac 的正确方式 根据苹果官方提供的清洁指南,小编整理了以下 ...

  4. 表格文字自动对齐 html6,Excel文字对齐技巧:学会这6种方式,快速整理规范表格...

    [温馨提示]亲爱的朋友,阅读之前请您点击[关注],您的支持将是我最大的动力! Excel制作表格中,文字在单元格内对齐的方式,我们经常用到的有居中对齐.居右对齐.居左对齐,对过这些对齐方式,可以编辑出 ...

  5. java 深拷贝 流_(转)Java技巧:深拷贝的两种方式

    ⑴浅复制(浅克隆) 被复制对象的所有变量都含有与原来的对象相同的值,而所有的对其他对象的引用仍然指向原来的对象.换言之,浅复制仅仅复制所考虑的对象,而不复制它所引用的对象. ⑵深复制(深克隆) 被复制 ...

  6. Java技巧:深拷贝的两种方式2(转)

    ②继承自java.lang.Object类的clone()方法是浅复制.以下代码可以证明之. class Professor { String name; int age; Professor(Str ...

  7. Java技巧:深拷贝的两种方式(转)

    拷贝构造函数,经常被称作X(X&),是一种特殊的构造函数,他由编译器调用来完成一些基于同一类的其他对象的构件及初始化.它的唯一的一个参数(对象的引用)是不可变的(因为是const型的). ⑴浅 ...

  8. 心田花开|写作技巧,人物心理描写八大方式

    人物描写细分有肖像描写.语言描写.动作描写.心理描写等.心田花开将系统的讲述和分析这几种描写的具体内容与手法. 今天心田花开讲解一下什么是心理描写. 所谓心理描写,就是对人物内心的思想活动.情感活动进 ...

  9. 如何在64位win7下通过ODAC来访问Oracle服务器

    最近公司跟我换了新电脑:2代i3+8G内存,由于32位的win7最多只能用3.25G内存,而用ramdisk4g划出4.75G来作硬盘又觉太浪费,遂想用64位的系统. 从网上下载了冷风的64位win7 ...

最新文章

  1. DNS and Bind (一)
  2. spring源码分析之定时任务Scheduled注解
  3. rtp h264打包和解包
  4. 「递归」第7集 | 腾讯开源联盟出征!
  5. 求最大值及其下标编程总结
  6. Scrum基础知识体系和感想
  7. 操作分布式文件之三:如何访问和操作远程文件
  8. 吴裕雄 Bootstrap 前端框架开发——Bootstrap 网格系统实例:响应式的列重置
  9. 【报告分享】2021新青年国货消费研究报告:文化觉醒时代,宝藏国货迎复兴机遇.pdf(附下载链接)...
  10. python中or的用法_解析python中and与or用法
  11. jQuery EasyUI使用教程之在数据网格中添加搜索功能
  12. [tp3.2.1]让默认页面: 加载Home模块的Index控制器;而让admin.php默认去加载Admin模块的Adminc控制器....
  13. 新手如何学习PLC编程?
  14. 寻找与黄金分割点最近的商
  15. 跟二项分布相关的统计检验方法
  16. 网易云音乐基于用户的推荐系统
  17. Mysql 5.7 表名大写遇到的坑 error: 1146: Table 'your_table' doesn't exist
  18. Shell/Linux使用Jq操作Json
  19. 优惠券使用---责任链模式
  20. IC/FPGA一文练完

热门文章

  1. 实验3 | 由遍历序列构造二叉树
  2. java线程池参数面试题,附赠复习资料
  3. echarts label固定位置_ECharts+百度地图网络拓扑应用
  4. rails 放在 apache一个目录下面的配置方法
  5. 对Faster R-CNN的理解(1)
  6. day06 hashlib模块
  7. Ocelot中文文档入门
  8. 被未知进程占用端口的解决办法
  9. LeetCode-46. Permutations
  10. mac下的svn服务器建立