有效建立Oracle dblink的兩種方式
兩台不同的資料庫伺服器,從一台資料庫伺服器的一個使用者讀取另一台資料庫伺服器下的某個使用者的資料,這個時候可以使用dblink。
其實dblink和資料庫中的view差不多,建dblink的時候需要知道待讀取資料庫的ip地址,ssid以及資料庫使用者名稱和密碼。
建立可以採用兩種方式:
1、已經配置本地服務
create public database link fwq12 connect to fzept identified by neu using 'fjept' ;
CREATE DATABASE LINK資料庫連結名CONNECT TO 使用者名稱 IDENTIFIED BY 密碼 USING ‘本地配置的資料的執行個體名’;
2、未配置本地服務
create database link linkfwq connect to fzept identified by neu using '(DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 10.142.202.12)(PORT = 1521)) ) (CONNECT_DATA = (SERVICE_NAME = fjept) ) )';
host=資料庫的ip地址,廣域網路:service_name=資料庫的ssid、區域網路SID=資料庫的ssid。
其實兩種方法配置dblink是差不多的,我個人感覺還是第二種方法比較好,這樣不受本地服務的影響。
資料庫連接字串可以用NET8 EASY CONFIG或者直接修改TNSNAMES.ORA裡定義。
資料庫參數global_name=true時,要求資料庫連結名稱跟遠端資料庫名稱一樣。
資料庫全域名稱可以用以下命令查出:
SELECT * FROM GLOBAL_NAME;
查詢遠端資料庫裡的表:
SELECT …… FROM 表名@資料庫連結名;
查詢、刪除和插入資料和操作本地的資料庫是一樣的,只不過表名需要寫成“表名@dblink伺服器”而已。
附帶說下同義字建立:
CREATE SYNONYM 同義字名 FOR 表名;
CREATE SYNONYM 同義字名 FOR 表名@資料庫連結名;
刪除dblink:DROP PUBLIC DATABASE LINK linkfwq。
如果建立全域dblink,必須使用systm或sys使用者,在database前加public。
參考資料: