標籤:
在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用戶端設定 本文由豆約翰部落格備份專家遠程一鍵發布
在net安裝程式中部署oracle用戶端全攻略