分享
 
 
 

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

王朝c#·作者佚名  2006-12-17
窄屏简体版  字體: |||超大  

主要的是要做三件工作: 打包文件,写注册表,注册环境变量

说明:我的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客户端设置

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有