今天在 x64 的 Win7 上重新安裝了 Oralce 後,通過 PL/SQL 串連資料庫時,提示如下錯誤資訊
環境
windows7 64bit
Oracle win64 11gR2
PL/SQL v9.0
詳細錯誤資訊
[plain] view
plaincopy
- Initialization error
- Could not initialize "C:\oracle\product\11.2.0\dbhome_1\bin\oci.dll"
- Make sure you have the 32 bits Oracle Client installed.
-
- OCIDLL forced to C:\oracle\product\11.2.0\dbhome_1\bin\oci.dll
- LoadLibrary(C:\oracle\product\11.2.0\dbhome_1\bin\oci.dll) returned 0
問題原因安裝完後Oracle的 oci.dll 是64位的,而32位應用程式 PLSQL Developer 無法載入。解決方案1. 從 http://www.oracle.com/technetwork/database/features/instant-client/index-097480.html 下載Oracle
Client Package。 我下載的是Instant Client for Microsoft Windows (32-bit) 【instantclient-basic-nt-11.2.0.2.0.zip】 2. 將 instantclient-basic-nt-11.2.0.2.0.zip 解壓至 c:\oracle, oci.dll 所在目錄為:c:\oracle\instantclient_11_2\3. 設定環境變數 TNS_ADMIN=c:\oracle\product\11.2.0\dbhome_1\NETWORK\ADMIN NLS_LANG=AMERICAN_AMERICA.ZHS16GBK (
註:NLS_LANG前半部分必須是AMERICAN_AMERICA,因為instant client不支援其他語言;而後半部分可以根據你資料庫的字元集調整,如果資料庫採用AL32UTF8,則可以設定AL32UTF8)4. 啟動PL/SQL Developer ,點擊“取消”不要登入,菜單 --> Tools --> Perferences --> Connection 修改 Oracle_Home 和 OCI Library 的配置:
OracleHome: OraDb11g_home1
OCI library: C:\oracle\instantclient_11_2\oci.dll5. 重新啟動 PL/SQL並登入對應的資料庫,串連正常,問題成功解決!原文出自:http://blog.csdn.net/hemingwang0902/article/details/7027543