半步多 玄玉的博客

OraclePLSQLDev运行在64bit环境下的方法

2012-03-19
玄玉

现象

Win7—64bit中安装了Oracle_win64_11gR2_databaseplsqldev715之后,启动plsqldev时发现其无法识别Oracle实例

原因

32位的应用程序PLSQL Developer 715在加载64位的oci.dll时出错

解决

获取InstantClient

下载地址为:http://www.oracle.com/technetwork/indexes/downloads/index.html

点击Database栏中的InstantClient,转向后页面中点击Instant Client for Microsoft Windows(32-bit)链接

然后在新页面中点击Accept License Agreement单选框,最后单击instantclient-basic-nt-11.2.0.2.0.zip下载链接

该链接的标注为:Instant Client Package - Basic: All files required to run OCI, OCCI, and JDBC-OCI applications

实际下载地址为:http://download.oracle.com/otn/nt/instantclient/112020/instantclient-basic-nt-11.2.0.2.0.zip

将下载到的47.9MB大小的instantclient-basic-nt-11.2.0.2.0.zip解压到本地

原则上可将其解压至任意目录,但不推荐路径名含有中文及空格(这里我解压到了//ORACLE_HOME//product//目录中)

配置数据库信息

再找到//ORACLE_HOME//product11.2.0//dbhome_1//NETWORK//ADMIN//目录中的tnsnames.ora文件

拷贝到instantclient_11_2根目录中,也可在该目录手工创建tnsnames.ora文件,其模版配置如下

系统标识符SID =
    (DESCRIPTION =
        (ADDRESS = (PROTOCOL = TCP)(HOST = 数据库服务器IP地址)(PORT = 端口))
        (CONNECT_DATA =
            (SERVER = DEDICATED)
            (SERVICE_NAME = 数据库服务名) 或者 (SID = 数据库服务名)
        )
    )

-- 下面是我实际用到的tnsnames.ora文件,内容如下:
DB.8.1 =
    (DESCRIPTION =
        (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.8.1)(PORT = 1521))
        (CONNECT_DATA =
            (SERVER = DEDICATED)
            (SID = NTDATA)
        )
    )

备注:可能会发现即使instantclient_11_2根目录中创建了tnsnames.ora文件后,plsqldve偶尔也会无法识别Oracle实例

于是我就索性一股脑将sqlnet.oralistener.oratnsnames.ora三个文件都拷贝到了instantclient_11_2根目录中

实践发现,这么做之后,就没有出现过plsqldev识别Oracle实例失败的现象了,大家可以参考一下

配置变量和参数

先配置系统环境变量,如下所示

Win7-->计算机-->属性-->高级系统设置-->环境变量-->系统变量中新增以下两个变量
TNS_ADMIN = %ORACLE_HOME%\product\instantclient_11_2
NLS_LANG = AMERICAN_AMERICA.AL32UTF8 或者 SIMPLIFIED CHINESE_CHINA.ZHS16GBK

其中AMERICAN_AMERICA是固定的,因为InstantClient不支持其他语言,而后半部分的AL32UTF8则取决于数据库的字符集

再配置plsqldev连接参数

plsqldev工具-->Tools-->Preferences-->Connection-->配置Oracle Home和OCI library路径
Oracle Home = %ORACLE_HOME%\product\instantclient_11_2(InstantClient的解压目录)
OCI library = %ORACLE_HOME%\product\instantclient_11_2\oci.dll

最后重启plsqldev即可

补充

也可以写一个批处理,来自动设置启动plsqldev时所需的变量。如下所示

@echo off
set TNS_ADMIN=D:\Develop\Oracle\product\instantclient_11_2
set NLS_LANG=AMERICAN_AMERICA.AL32UTF8
start D:\ProgramFiles\PLSQLDeveloper\plsqldev.exe

上一篇 Linux基础知识

下一篇 Oracle命令小结

Comments

Content