Win 2008 R2 x64 PL/SQL 连接 Oralce 提示 Could not initialize "%ORACLE_HOME%\bin\oci.dll"

  • 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 

http://www.oracle.com/technetwork/topics/winsoft-085727.html

下载Oracle Client Package。 我下载的是Instant Client for Microsoft Windows (32-bit) 【instantclient-basic-nt-11.2.0.2.0.zip】 (注意:下载之前需要登录Oracle网站)

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并登录对应的数据库

 

REF:

http://q.cnblogs.com/q/14105/

http://blog.csdn.net/hemingwang0902/article/details/7027543

http://www.cnblogs.com/dba001/archive/2011/08/13/2137561.html

posted @ 2012-12-18 22:37  emanlee  阅读(2648)  评论(0编辑  收藏  举报