db link的查看建立與刪除

前言:sql

兩臺不一樣的數據庫服務器,從一臺數據庫服務器的一個用戶讀取另外一臺數據庫服務器下的某個用戶的數據,這個時候能夠使用dblink。
其實dblink和數據庫中的view差很少,建dblink的時候須要知道待讀取數據庫的ip地址,ssid以及數據庫用戶名和密碼。數據庫

1.查看dblink服務器

select owner,object_name from dba_objects where object_type='DATABASE LINK';

或者app

select * from dba_db_links;

2.建立dblink
前提:
    建立dblink的用戶有對應的數據庫權限
        create public database link 或者create database link
        能夠使用ide

grant create public database link,create database link to myAccount;

        來受權.spa

create public database link dblinkname connect to username identified by password
   using '(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = database_ip)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME =servicename)
)
)';
若是在create以後不加public,則建立的dblink就不是公共的,就只有建立者能夠使用了.
補充:如何肯定數據庫的servicename:
    1.在sqlplus中使用code

show parameter[s] service_names;

        注意parameter和parameters均可以
    2.使用ip

select name,value from v$parameter where name='service_names'


   
3.使用db link
    例如,在本機數據庫上建立了一個scott_rmthost的public dblink(使用遠程主機的scott用戶鏈接),則用sqlplus鏈接到本機數據庫,執行select * from scott.emp@scott_rmthot便可以將遠程數據庫上的scott用戶下的emp表中的數據獲取到.
    也能夠在本地建一個同義詞來指向scott.emp@scott_rmthost,這樣取值就方便多了.io

4.刪除
    注意:用戶有create public database link 或者create database link 權限. object

drop public database link dblinkname;
相關文章
相關標籤/搜索