Win7 x64 PL/SQL 連接 Oralce 提示 Could not initialize "%ORACLE_HOME%\bin\oci.dll"

今天在 x64 的 Win7 上重新安裝了 Oralce 後,通過 PL/SQL 連接數據庫時,提示如下錯誤信息


環境

windows7 64bit

Oracle win64 11gR2

PL/SQL v9.0

詳細錯誤信息

[plain] view plain copy

  1. Initialization error  

  2. Could not initialize "C:\oracle\product\11.2.0\dbhome_1\bin\oci.dll"  

  3. Make sure you have the 32 bits Oracle Client installed.  

  4.   

  5. OCIDLL forced to C:\oracle\product\11.2.0\dbhome_1\bin\oci.dll  

  6. 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.dll


5. 重新啓動 PL/SQL並登錄對應的數據庫,連接正常,問題成功解決!


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章