오라클(Oracle) DB link의 생성과 삭제

Last Updated on 11월 21, 2020 by 태랑(정현호)


2020/11/21 업데이트

tnsnames.ora 수정


먼저 dblink 를 생성전 tnsnames.ora 에서 추가합니다


리눅스기준
$ORACLE_HOME/network/admin  의 위치에 tnsnames.ora 파일이 있습니다


db_alias =
  (DESCRIPTION =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 접속하는곳IP)(PORT = 1521))
        (CONNECT_DATA =
               (SERVER = DEDICATED)
                 (SERVICE_NAME = 접속대상DB의 SID)
                             )  
                         )




db_alias 를 testdb2 로 지정하고 접속할주소는 testdb2.com 이며 해당 db SID가 orcl 이라면 아래와같이 추가 해주면 됩니다


testdb2=
  (DESCRIPTION =
      (ADDRESS = (PROTOCOL = TCP)(HOST = testdb2.com)(PORT = 1521))
         (CONNECT_DATA =
               (SERVER = DEDICATED)
                   (SERVICE_NAME = orcl)
                             )  
                         )



DB LINK 생성


# DBLINK 생성 구문 
SQL>
CREATE [PUBLIC] DATABASE LINK link_name
         [CONNECT TO CURRENT_USER]
         [USING 'connect_string']  


SQL> CREATE DATABASE LINK 링크이름
CONNECT TO <연결하고자 하는 user>
IDENTIFIED BY <연결하고자 하는 user password>
USING '원격 db alias'


위와 같이 생성 하면 되며 기본적으로 DB LINK를 생성한 유저만 이용이 가능합니다.



아래와 같이 public 옵션이 들어가면 누구나 이용 가능하게 됩니다.
SQL> CREATE PUBLIC DATABASE LINK 링크이름
CONNECT TO <연결하고자 하는 user>
IDENTIFIED BY <연결하고자 하는 user password>
USING '원격 db alias'



삭제 할 때 에도 생성된 형태에 따라 삭제 방법이 약간 다릅니다


누구나 사용이 가능한 public 형태 라면 
SQL> drop public database link db_link이름;



생성된 사용자만 이용 가능한 private 하게 되어있다면 해당유저로 접속해서
drop database link db_link이름;          
하면 됩니다




DBLINK 생성 권한


일반유저에게 Private DB LINK 생성권한 부여
SQL> grant create database link to 유저명;


Public 으로 생성 할 수 있는 권한 부여
SQL> grant create public database link to 유저명;


dba_db_links dictionary 에서 자세한 내용 조회 가능합니다

SQL> select * from dba_db_links;


사용법은 다음 과 같습니다.
select 컬럼명 from 테이블명@db_link명


답글 남기기