热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

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

欢迎进入Oracle社区论坛,与200万技术人员互动交流进入主要的是要做三件工作:打包文件,写注册表,注册环境变量说明:我的oracle版本为9,在2000advancedserver上测试通过,可以正常创建数据库连接1.打包文件目录结果如下图所示以下是我的打包程序中

欢迎进入Oracle社区论坛,与200万技术人员互动交流 >>进入 主要的是要做三件工作: 打包文件,写注册表,注册环境变量 说明:我的oracle版本为9, 在2000 advanced server 上测试通过,可以正常创建数据库连接 1.打包文件 目录结果如下图所示 以下是我的打包程序中

欢迎进入Oracle社区论坛,与200万技术人员互动交流 >>进入

主要的是要做三件工作: 打包文件,写注册表,注册环境变量
说明:我的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
--------------------

networkadmin : 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)
)
)


ocommonnlsADMINDATA: 原oracle安装目录下所有文件
oracorezoneinfo : timezone.dat

2.写注册表
HKEY_LOCAL_MACHINESOFTWAREORACLE
???"ORACLE_HOME" = "c:oracleora90"
我发现从网上查到的 HKEY_LOCAL_MACHINESOFTWAREORACLEHOME0下的ORACLE_HOME值并不是必须的.

3.注册环境变量
HKEY_LOCAL_MACHINESYSTEMControlSet001ControlSession ManagerEnvironment
???"path" += "D:oracleora90bin;"

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

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

示例代码如下:



#region 检查Oracle客户端设置
///
/// 检查Oracle客户端设置
///
private void CheckOracleClient() {
string[] keys = { "SYSTEM", "ControlSet001", "Control", "Session Manager", "Environment" };
this.SetRegistryKey(Registry.LocalMachine, keys, "Path", @"c:oracleora90bin", true);
keys = new string[] { "Software", "ORACLE"};
this.SetRegistryKey(Registry.LocalMachine, keys, "ORACLE_HOME", @"C:oracleora90", false);
}

///
/// 将指定的值写入注册表
///
/// 初始的注册表项
/// 注册表项数组,表示了指定值的路径
/// 值的名称
/// 要写入的值
/// 是否在当前值前添加,若为否,则覆盖当前值
private void SetRegistryKey(RegistryKey startKey, string[] registryKeys, string valueName, string value, bool append) {

RegistryKey rk = startKey;
RegistryKey subKey = null;
for (int i=0; i subKey = rk.OpenSubKey(registryKeys[i], true);
if (subKey == null) {
subKey = rk.CreateSubKey(registryKeys[i]);
}
rk = subKey;
}

if (append) {
if (rk.GetValue(valueName) == null) {
rk.SetValue(valueName, value);
} else {
string oldValue = rk.GetValue(valueName).ToString();
if (oldValue.IndexOf(value) > 0) {
rk.SetValue(valueName, value + ";" + oldValue);
}
}
} else {
if (rk.GetValue(valueName) == null) {
rk.SetValue(valueName, value);
rk.Flush();
}
}
if (subKey != null) {
subKey.Close();
}
rk.Flush();
rk.Close();
}
#endregion 检查Oracle客户端设置


推荐阅读
  • 本文探讨了为何DataWindow.NET在PowerBuilder 11之后版本中不再被支持,并提供了一种在PB12.5中恢复此功能的解决方案。欢迎交流与反馈。 ... [详细]
  • 本文档详细介绍了服务器与应用系统迁移的策略与实施步骤。迁移不仅涉及数据的转移,还包括环境配置、应用兼容性测试等多个方面,旨在确保迁移过程的顺利进行及迁移后的系统稳定运行。 ... [详细]
  • SonarQube配置与使用指南
    本文档详细介绍了SonarQube的配置方法及使用流程,包括环境准备、样本分析、数据库配置、项目属性文件解析以及插件安装等内容,适用于具有Linux基础操作能力的用户。 ... [详细]
  • 本文详细介绍了MySQL在Linux环境下的主从复制技术,包括单向复制、双向复制、级联复制及异步复制等多种模式。主从复制架构中,一个主服务器(Master)可与一个或多个从服务器(Slave)建立连接,实现数据的实时同步。 ... [详细]
  • Redis 教程01 —— 如何安装 Redis
    本文介绍了 Redis,这是一个由 Salvatore Sanfilippo 开发的键值存储系统。Redis 是一款开源且高性能的数据库,支持多种数据结构存储,并提供了丰富的功能和特性。 ... [详细]
  • PHPFORMYSQL代码生成助手(根据Mysql里的字段自动生成类文件的)_PHP教程:根据Mysql里的字段自动生成类文件:但需要导入:require_once.dbez_sq ... [详细]
  • 本文深入探讨了Redis的快照持久化机制,包括其工作原理、配置方法以及如何手动触发快照。通过这种方式,Redis能够确保在服务器重启后数据的安全性和完整性。 ... [详细]
  • 一个产品数组拼图|集合 2 (O(1)空间) ... [详细]
  • ###########性能监控脚本###########################!binbash#监控cpu系统负载IPifconfigeth0|grepinetaddr ... [详细]
  • 本文详细解析了工业机器人控制柜内部的关键组件及其作用,包括轴计算机、安全面板、电容、驱动器、动力线、SMB线、跟踪板及外部轴上的电源装置等,旨在为读者提供全面的技术指导。 ... [详细]
  • 本文介绍了几种有效的方法来加速Windows 10系统的更新下载过程,帮助用户解决更新下载速度慢的问题。 ... [详细]
  • 本文探讨了在技术文档中如何专业地表达‘宕机’这一概念,以提高文档的准确性和专业性。 ... [详细]
  • APP数据包捕获挑战
    本文探讨了在使用Burp Suite捕获移动应用数据包时遇到的两大难题,尤其是SSL Pinning安全机制的影响,并提供了一种解决方案。 ... [详细]
  • 本文详细介绍了PHP汽车租赁网站源码的获取方式、本地部署步骤以及汽车租赁系统的功能模块,适合开发者和技术爱好者参考。 ... [详细]
  • 解决CSS因MIME类型不匹配导致的加载失败问题
    本文详细介绍了在Web开发过程中,遇到CSS文件因MIME类型不匹配而无法正确加载的问题及其解决方案,适合前端开发者阅读。 ... [详细]
author-avatar
琴瑟_0203
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有