未安装oracle情况下,plsql或toad远程连接oracle

时间:2021-09-07 08:34:36

如果本机只有plsql、toad等oracle图形操作工具的情况下去连接远程数据库,而本机没有安装Oracle的情况,如何连接?
没有安装oracle就会少一些必要的配置文件,而Oracle的Instant client工具包可以很好地解决这个问题,小而且比较方便。
 
第一步 -- 去Oracle官网下载Instant Client :  http://www.oracle.com/us/solutions/index-097480.html

解压之后的文件夹叫:instantclient_11_2.可以放在本地磁盘任意目录下.例如:F:/instantclient_11_2

第二部 -- 在F:/instantclient_11_2目录下新建目录network,在network目录下新建目录admin,在admin目录下新建文件tnsnames.ora,打开写入如下内容:

ORCL =
(DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 10.6.8.10 )(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVICE_NAME = orcl )
    )
)

其中ORCL是远程数据库在本地的主机名,10.6.8.10是远程服务器的IP地址,orcl是远程数据库的名称。

第三步 -- 添加一个环境变量,名为TNS_ADMIN,值为tnsnames.ora文件所在路径。
通过(我的电脑--属性--高级--环境变量--新建)来新增环境变量。

第四步(toad) -- 下载并安装toad
 我的oracle home editor中的配置信息如下:
 未安装oracle情况下,plsql或toad远程连接oracle

第四步(PL.SQL) -- 下载并安装PL.SQL.Developer配置应用
配置tools->preferences->connection

Oracle Home
F:/instantclient_11_2

OCI library
F:/instantclient_11_2/oci.dll

配置完成后关闭PL/SQL ,再重启.

主机名就会出现在PL/SQL Developer的列表里,输入用户名密码,就可以登录远程oracle 数据库。

当我们连接成功后有时候查询出来的数据会出现乱码的问题,这是因为本地的编码和服务器端编码不一致,这时候我们可以通过SQL语句:

select userenv('language') from dual;

查询出服务器端的编码,如我自己的查询结果为

USERENV('LANGUAGE')
AMERICAN_AMERICA.ZHS16GBK

我们就需要添加一个环境变量NLS_LANG ,值为: AMERICAN_AMERICA.ZHS16GBK 然后重启PL/SQL就不会再有乱码问题了。