因爲Oracle的龐大,有時候咱們須要在只安裝Oracle客戶端如plsql、toad等的狀況下去鏈接遠程數據庫,但是沒有安裝Oracle就沒有一切的配置文件去支持。最後終於發現一個頗有效的方法,Oracle的Instant client工具包能夠很好地解決這個問題,並且小而方便。
一、首先到Oracle網站下載Instant Client :
http://www.oracle.com/us/solutions/index-097480.html
解壓以後的文件夾叫:instantclient_11_2.能夠放在本地磁盤任意目錄下.例如:D:/instantclient_11_2
二、在D:/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文件所在路徑。
經過(個人電腦--屬性--高級--環境變量--新建)來新增環境變量。
四、下載並安裝PL.SQL.Developer配置應用
配置tools->preferences->connection
Oracle Home
D:/instantclient_11_2
OCI library
D:/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就不會再有亂碼問題了。html