问题原因:有一天,我改了NLS_LANG的字符集重启之后就发生了PL/SQL无法连接ORACLE的问题了。在网上找了很久,找到这篇文档,感觉甚好。最终恢复连接。
安装完后Oracle的 11.2.0的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-12.1.0.zip】
链接:https://pan.baidu.com/s/1SKzw4P9dsGJcZW56DgNjEA
提取码:n7b4
复制这段内容后打开百度网盘手机App,操作更方便哦
2. 将 instantclient-basic-nt-12.1.0.zip 解压至 d:\,即(D盘) 。oci.dll 所在目录为:d:\instantclient.12.1.0\
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: D:\instantclient.12.1.0
OCI library:D:\instantclient.12.1.0\oci.dll
5.重新启动PL/SQL Developer
出错的时候,数据库是加载不出来的。现在好了。
6.至于下面的数据库显示,比如说ORCL105.ORCL106是在 C:\app\dingmx\product\instantclient.11.2.0\NETWORK\ADMIN\tnsnames.ora
这里进行进行写入的。orcl启动的时候,会自动加载这个文件夹,并非像之前猜想的d:\instantclient.12.1.0\NETWORK\ADMIN\tnsnames.ora。