在.net安装程序中部署oracle客户端全攻略
2004-11-29 21:19
711 查看
主要的是要做三件工作: 打包文件,写注册表,注册环境变量
说明:我的oracle版本为9, 在2000 advanced server 上测试通过,可以正常创建数据库连接
1.打包文件
目录结果如下图所示
以下是我的打包程序中的文件目录,
bin : 最重要的当然是bin目录,在我的打包程序中,需要29个文件:
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的部署程序中,文件系统->特殊文件夹).有点恶毒阿,不过临时凑活着吧 :) 谁找到解决的办法记得告诉我阿
示例代码如下:
说明:我的oracle版本为9, 在2000 advanced server 上测试通过,可以正常创建数据库连接
1.打包文件
目录结果如下图所示
以下是我的打包程序中的文件目录,
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 -------------------- |
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的部署程序中,文件系统->特殊文件夹).有点恶毒阿,不过临时凑活着吧 :) 谁找到解决的办法记得告诉我阿
示例代码如下:
相关文章推荐
- oracle date 类型字段的处理方法
- oracle常用sql查询语句部分集合(图文)
- ATL实现Connection Point的一种简单的方法
- ORACLE9i连接SYBASE的透明网关的配置
- Microsoft Visual Studio .NET 2003制作安装程序
- PHP 的 MySQL 操作类,跟手册上的函数一样用,但是更方便了。多说无益,看了就知道了。
- Java测试规范(引用)
- duwamish7的感悟!
- oracle中的分页
- SELECT TOP N 问题
- Java面试题目
- delphi中的时间操作技术(2)
- 解析IP地址为主机域名
- 将某一主机域名解析为IP地址
- JCreator Pro 3.0与WTK2.0配置心得
- 有关TrueDBGrid的问题向各位大虾请教
- 力争最简单把*、&说清楚
- 一个画图类,类似ms_chart的线图,适用于科学仿真数据分析(一)
- 好久没来CSDN了,因为一直在忙考试....