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

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

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的部署程序中,文件系统->特殊文件夹).有点恶毒阿,不过临时凑活着吧 :) 谁找到解决的办法记得告诉我阿

示例代码如下:

#region 检查Oracle客户端设置
        ///

        /// 检查Oracle客户端设置
        /// 

        private void CheckOracleClient() {
            string[] keys = { "SYSTEM", "ControlSet001", "Control", "Session Manager", "Environment" };
            this.SetRegistryKey(Registry.LocalMachine, keys, "Path", @"c:/oracle/ora90/bin", true);
            keys = new string[] { "Software", "ORACLE"};
            this.SetRegistryKey(Registry.LocalMachine, keys, "ORACLE_HOME", @"C:/oracle/ora90", false);
        }

        ///

        /// 将指定的值写入注册表
        /// 

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

            RegistryKey rk = startKey;
            RegistryKey subKey = null;
            for (int i=0; i<registryKeys.GetLength(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客户端设置

本文由豆约翰博客备份专家远程一键发布

时间: 2024-10-09 11:20:13

在net安装程序中部署oracle客户端全攻略的相关文章

webBrowser中操作网页元素全攻略

webBrowser中操作网页元素全攻略 2012-12-20 14:21 188人阅读 评论(0) 收藏 举报 1.获取非input控件的值: webBrowser1.Document.All["控件ID"].InnerText; 或webBrowser1.Document.GetElementById("控件ID").InnerText; 或webBrowser1.Document.GetElementById("控件ID").GetAttr

大型ECShop安装搬家升级错误问题最全攻略

[引子] 最近将ECShop框架网站从租用服务器搬家至阿里云,虽然模块及功能上已经被修改的面目全非了,但基础部分还在. 在这个过程中遇到了很多的WARNING与ERROR,解决方案如下. [环境] 服务器环境由PHP5.3+MySQL5.6更新至PHP5.6+MySQL5.7 [数据库] 利用navicat for mysql工具导入导出,出现异常:Invalid default value for 'create_time',具体可参考上一篇随笔.http://www.cnblogs.com/

VS建立的Winform程序中连接Oracle数据库能正常运行在Web中却不能正常连接运行可能原因(本文来自博客园深蓝居)

我们平时使用的都是32位的机器进行开发,装的都是32位的软件,但是我们的服务器一般都是64位的,所以有时也需要在64位的环境下装一个VS调试程序.最近遇到的一个问题就是一个同事换了一个电脑,用的是X64的Windows 2008作为操作系统,要进行Oracle的数据库连接,所以也装了64位的Oracle客户端.如果是控制应用项目或者WinForm项目可以正常连接Oracle,但是Web项目在程序中打开Oracle连接时,系统抛出了异常: 尝试加载 Oracle 客户端库时引发 BadImageF

C#应用程序中读取Oracle数据库

前言 最近的任务就是开发了一个功能,要从供应商那边读取数据,然后拿过来,处理以后放到我们自己的数据库中.供应商那边是Oracle数据库,其实不管什么数据我想都差不多,于是我就开始了.由于在家里写的博客,那些截图都放在公司电脑了,希望能通过文字让大家明白,多有不周还请原谅. 过程 第一种方法:一开始我是用的.net里面自带的那个System.Data.OracleClient;引用.然后把Oracle客户端装了,结果不行.Oracle客户端装的是及时版本.执行后不断的报错,什么无法标示了,版本得多

VMware vsphere平台中部署 Oracle RAC(二、NTP配置和SSH信任)

NTP 配置两个节点检查是否安装ntp rpm -q ntp///如果没安装就yum -y install ntp 进行安装///systemctl enable ntpd systemctl enable ntpd.service 设置开机启动ntpsystemctl start ntpd 启动ntpsystemctl status ntpd 查看ntp状态 -----racdb1 作为NTP服务端和客户端配置---------vi /etc/ntp.conf# 外部时间服务器不可用时,以本地

[转]MSI安装程序中的文件替换

原文链接:http://teach.hanzify.org/article/652-1233562028.html 前言 最近有汉化朋友问起如何不重新制作MSI文件,而直接用汉化好的文件替换MSI安装程序中的文件.为此,将本人的实践经验作个总结,供各位汉化人参考.有错误的地方烦请指正.※说明:目前可以用于MSI编辑的软件很多,但是有些软件在保存时会在MSI文件中写入一些自己的表或内容,有些会另外嵌入一个CAB文件,使得MSI文件增大.而这里提供的方法保证不会写入任何不必要的内容和文件.※关键点:

Wix安装程序中判断是否安装的.net framwork 4.5

Wix安装程序中判断是否安装的.net framwork 4.5 <PropertyRef Id="NETFRAMEWORK40FULL"/> <PropertyRef Id="NETFRAMEWORK45"/> <Condition Message='This setup requires Microsoft .NET Framework 4.0 Full package or greater needs to be installe

Emacs安装配置全攻略之一编译安装简单配置

/******************************************************************************************************************************************/ 原创作品,转载时请务必以超链接形式标明文章原始出处:http://blog.csdn.net/gqb_driver/article/details/29407717,作者:gqb666 /***************

android开发新浪微博客户端 完整攻略 [新手必读]

开始接触学习android已经有3个礼拜了,一直都是对着android的sdk文档写Tutorials从Hello World到Notepad Tutorial算是初步入门了吧,刚好最近对微博感兴趣就打算开发个android版本的新浪微博客户端作为练手项目,并且以随笔的方式详细的记录开发的全过程.本人对java语言以及eclipse Ide都是初次应用基本上属于边学边用,做移动设备上的东西也是第一次,总的来说属于无基础.无经验.无天赋的纯三无人员,还请广大同学们多多给予指点. 开发第一件事情,那