在.net安装程序中部署oracle客户端全攻略

主要的是要做三件工作: 打包文件,写注册表,注册环境变量
说明:我的oracle版本为9, 在2000 advanced server 上测试通过,可以正常创建数据库连接


1.打包文件
目录结果如下图所示

oralce客户端

以下是我的打包程序中的文件目录,
bin : 最重要的当然是bin目录,在我的打包程序中,需要29个文件:

--------------------
oci.dll
oraclient9.dll
oracommon9.dll
ORACORE9.DLL
orageneric9.dll
oraldapclnt9.dll
oran9.dll
ORANCDS9.DLL
orancrypt9.dll
oranhost9.dll
oranl9.dll
oranldap9.dll
ORANLS9.DLL
oranms.dll
oranmsp.dll
orannts9.dll
orannzsbb9.dll
oranoname9.dll
oranro9.dll
orantcp9.dll
orantns9.dll
ORAPLS9.DLL
ORASLAX9.DLL
ORASNLS9.DLL
ORASQL9.DLL
oratrace9.dll
ORAUNLS9.DLL
oravsn9.dll
orawtc9.dll
--------------------

network/admin : tnsnames.ora
tnsnames.ora文件内容如下:(SERVICE_NAME = 服务器的连接)
ORCL =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = xxx.xxx.xxx.xxx)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = orcl)
)
)

ocommon/nls/ADMIN/DATA: 原oracle安装目录下所有文件
oracore/zoneinfo : timezone.dat

2.写注册表
HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE
"ORACLE_HOME" = "c:/oracle/ora90"
我发现从网上查到的 HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE/HOME0下的ORACLE_HOME值并不是必须的.

3.注册环境变量
HKEY_LOCAL_MACHINE/SYSTEM/ControlSet001/Control/Session Manager/Environment
"path" += "D:/oracle/ora90/bin;"

这里需要注意的是最好不用把path直接设成这个值,这样会覆盖掉系统原有的path,所以最好是在原有的path上添加.但是.net安装程序中通过直接设置注册表无法做到,这时候可以通过添加自定义安装操作来在程序中完成.

一个问题是在设置path后不会立即生效,所以安装完程序后,系统找不到oracle的bin目录,无法建立数据库连接. 我现在的做法是把bin目录下的29个文件都拷贝到系统的[System目录](在.net的部署程序中,文件系统->特殊文件夹).有点恶毒阿,不过临时凑活着吧 :) 谁找到解决的办法记得告诉我阿

示例代码如下:

    

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值