(转)不用安装oracle客户端,PL/SQL也能远程访问数据库

时间:2022-09-12 20:07:58

最近在网上看到有人说,不安装客户端也可以PL.SQL.Developer直接远程连接服务器,但搜了下没有完整的操作说明,大多都是支言片语,所以自己尝试着测试了一下,结果真的可以,现在把整个操作过程和大家分享,有不对的地方,大家要多提意见:

1、在安装ORACLE服务器的机器上搜索下列文件:
oci.dll
ocijdbc10.dll
ociw32.dll
orannzsbb10.dll
oraocci10.dll
oraociei10.dll
sqlnet.ora


tnsnames.ora (tnsnames.ora文件在%ORACLE_HOME%networkadmin下)
classes12.jar
ojdbc14.jar
放到一个文件夹,命名为oraclient(可随意) (这些文件可能个别的在服务器上没有,可以到网上下载,当然也可以联系我)

2、配置tnsnames.ora (记事本打开)# tnsnames.ora Network Configuration File: E:oracleproduct10.2.0db_2networkadmintnsnames.ora
# Generated by Oracle configuration tools.

LISTENER_ORCL(这里为oracledata,文件拷过来就有) =
(ADDRESS = (PROTOCOL = TCP)(HOST = 服务器IP)(PORT = 1522))

ORCL (这里为oracledata,文件拷过来就有)=
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 服务器IP)(PORT = 1522))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = 数据库实例名)
)
)

EXTPROC_CONNECTION_DATA =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC2))
)
(CONNECT_DATA =
(SID = PLSExtProc)
(PRESENTATION = RO)
)
)

3、添加一个环境变量,名为TNS_ADMIN,值为tnsnames.ora文件所在路径(如:D:oraclient,特别是重装后或其它操作,忘了TNS_ADMIN变量,plsql登陆就会报无法解析指定的连接标识符),这是为了能够找到上面说的tnsnames.ora。

我的电脑——(右键)属性——高级——点击环境变量——新建系统变量

如果本机上安装了ORACLE,并且设置了ORACLE_HOME环境变量,那么会自动在%ORACLE_HOME%/network/admin/位置查找tnsnames.ora文件。

4、设置ORACLE的语言,添加环境变量:
“NLS_LANG = SIMPLIFIEDCHINESE_CHINA.ZHS16GBK”,(AMERICAN_AMERICA.US7ASCII 是ASCII编码类型,其它类型可自己到服务器看一下或网上查找一下)

5、下载并安装PL.SQL.Developer配置应用(PL.SQL.Developer也可以下载绿色版,这样所有客户端都不需要安装软件
配置tools->preferences->connection
Oracle Home=D:oracleclient
OCI library=D:oracleclientoci.dll

打开PL.SQL.Developer,点击Cancel,进入未登录的程序。

打开tools->preferences->connection,做如下设置

Oracle Home=D:oracleclient
OCI library=D:oracleclientoci.dll

点击OK,关闭PL.SQL.Developer程序。

6、再次打开PL.SQL.Developer,则会在database中有服务器上面的oracledata 选项,输入用户名密码就可以登陆。

7、开启服务器及客户端防火墙(客户端和服务器都需要开启防火墙),可以直接关闭,或者在例外中把oracle相关程序设置为例外,具体设置可在网上搜索,这方面资料很多。大家如有其它问题,请多交流,感谢关注!