CTAS 를 통한 테이블 복제시 제약 조건
Local | Remote | |
Column Name, Type, Length | 그대로 Copy 됨 | |
Column Default Value | No | |
Index | No | |
Constraint | No | |
Not Null ( PK 에 의한 Not Null 포함 ) | 그대로 Copy 됨그대로 Copy 됨 | |
Grant | No | |
Synonym | No | |
Trigger | No |
테스트 결과는 첨부 화일 참조 바랍니다.
1. CTAS 의 경우 Parallel Hint 는
CT(Create Table) 에서는 사용하여도 의미가 없고(ORACLE 이 무시함),
AS 에서만 Parallel Hint 를 사용한다.
(As Select /*+ paralllel(a) parallel(b) */ * from tab1 a, tab2 b)
식으로 사용한다.
2. 캐릭터셋의 다른 DBMS 간의 CTAS 사용시 Column Size 가 달리 될수 있다.
[ 참고 - http://cafe.naver.com/prodba/2014 ]
이 경우 _keep_remote_column_size=true 로 설정 후 DB Restart 후에 CTAS 를 사용하면 된다고함
_keep_remote_column_size 파라미터의 의미 : remote column size does not get modified
Default 값은 False 임
3. 그럼 가장 빠르게 테이블 복제 [ Export / Import 제외 ]
3.1 Create Table COPY_Table as select * from Source_Table@remote where 1=2
를 통해서 테이블 껍데기만 Copy 후에
3.2 alter session enable parallel dml;
3.3 insert /*+ parallel(Copy_Table, 10) */ into Copy_Table nologging
select /*+ parallel(Source_table, 10) */ * from Source_Table@remote ;
3.4 Creae index ... Nologging PARALLEL ;
CREATE INDEX XAK_COPY_Table ... NOLOGGING PARALLEL ;
3.5 ALTER index ... LOGGING NOPARALLEL ;
ALTER index XAK_COPY_Table logging noparallel ;
3.6 통계정보 수집
exec dbms_stats.gather_table_stats(ownname=>user, tabname=>'COPY_Table ');
3.7 기타 추가 작업
Column Default Value, Index, Constraint, Grant, Synonym, Trigger
4. CTAS 를 쓸것인가 ? Export/Import 를 쓸것인가 ?
CTAS - Parallel 처리가 가능하다는 강점이 있다.
단. DB Link 를 통해서 통신 하기 때문에, Network 로 근거리(한국 내 정도 ^^;)어야 하고,
양쪽 DB 의 Characterset 이 동일 해야 한다. 기타 DB LInk 사용에 따른 제약이 없어야 한다.
Export/Import - Dump 화일 생성을 위한 저장할 공간이 필요하다.
양쪽 DB 의 Characterset 이 다르더라도, Sub Set 에서 Super Set 으로 이관시 아무런
문제가 되지 않는다. 비교적 먼거리 시에는 Remote 에서 Dump 화일 생성, ftp 전송,
Local Import 수행이 가능하다.
[출처] CTAS 를 통한 테이블 복제시 제약 조건|작성자 타락천사
'ORACLE > ADMIN' 카테고리의 다른 글
REDO log buffer 캐쉬의 튜닝 및 REDO Latch 경합의 해결 방법 (0) | 2009.11.06 |
---|---|
DDL - 오라클 Create table as select(CTAS) (0) | 2009.11.06 |
[Oracle] Primary Key 수정 (0) | 2009.10.30 |
oracle shrink (0) | 2009.10.09 |
REDO 와 UNDO를 차이점에서 바라본 관점 (0) | 2009.10.07 |