Background Image
조회 수 18461 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

1. 내용

 

파티션 테이블을 생성한 상태에서 인덱스를 생성하고,

생성된 파티션 테이블을 alter를 거쳐 일부 파티션을 삭제하면 INDEX도 같이 삭제되어야 하나 그렇지 않은 현상이 발생한다.

 

* cubrid diagdb 를 통해 보면 파티션 된 해당 인덱스는 삭제되지 않고 남아 있음을 알 수 있다.

이 부분은 사용되지 않는 부분으로 동작 자체에는 관여하지 않으나 디스크 공간을 계속 차지한다는 것을 감안해야 한다.

 

* cubrid checkdb 시 이 부분으로 인해 오류가 발생할 수 있다. 그러나 데이터 자체는 정상이다.

 

* cubrid backupdb 시 역시 이 부분으로 오류가 발생할 수 있다. cubrid checkdb 때와 같은 원인으로, cubrid backupdb 시 기본적으로 check를 우선 수행하기 때문이다. --no-check 옵션을 주어 cubrid backupdb 명령을 수행할 수 있다.

2. 예시

 

예시 1 - 테이블 및 인덱스 생성

csql >

CREATE TABLE participant2 (host_year INT, nation CHAR(3), gold INT, silver INT, bronze INT)

PARTITION BY RANGE (host_year)

(PARTITION before_1996 VALUES LESS THAN (1996),

PARTITION before_2008 VALUES LESS THAN (2008) );

 

INSERT INTO participant2 VALUES (1988, 'NZL', 3, 2, 8);

INSERT INTO participant2 VALUES (1988, 'CAN', 3, 2, 5);

INSERT INTO participant2 VALUES (1996, 'KOR', 7, 15, 5);

INSERT INTO participant2 VALUES (2000, 'RUS', 32, 28, 28);

INSERT INTO participant2 VALUES (2004, 'JPN', 16, 9, 12);

 

create index participant2_idx on participant2(host_year);

 

csql > ;exit

 

예시 2. 데이터베이스 저장상태 확인

$ cubrid server stop

 

$ cubrid diagdb -d2 demodb

---------------------------------------------------------------------------

   0|1557     1  HEAP                   CLASS_OID: 0| 505| 2 (participant2)

   0|1558     1  HEAP                   CLASS_OID: 0| 505| 3 (participant2__p__before_1996)

   0|1559     1  HEAP                   CLASS_OID: 0| 504| 2 (participant2__p__before_2008)

   0|1563     2  BTREE                  CLASS_OID: 0| 505| 3 (participant2__p__before_1996), ATTRID:  4

   0|1564     2  BTREE                  CLASS_OID: 0| 504| 2 (participant2__p__before_2008), ATTRID:  4

   0|1565     1  BTREE                  CLASS_OID: 0| 505| 2 (participant2), ATTRID:  4

---------------------------------------------------------------------------

 

 

예시 3. 파티션 일부 삭제

$ cubrid server start

csql >

alter table participant2 drop partition before_1996;

;x

 

 

예시 4. 파티션 일부 삭제 후 데이터베이스 저장 상태 확인

$ cubrid server stop

$ cubrid diagdb -d2 demodb

---------------------------------------------------------------------------

 

   0|1557     1  HEAP                   CLASS_OID: 0| 505| 2 (participant2)

   0|1558     1  HEAP                   Marked as deleted...CLASS_OID: 0| 505| 3 (*UNKNOWN-CLASS*)

   0|1559     1  HEAP                   CLASS_OID: 0| 504| 2 (participant2__p__before_2008)

   0|1563     2  BTREE                  CLASS_OID: 0| 505| 3 (*UNKNOWN-CLASS*), ATTRID:  4

   0|1564     2  BTREE                  CLASS_OID: 0| 504| 2 (participant2__p__before_2008), ATTRID:  4

   0|1565     1  BTREE                  CLASS_OID: 0| 505| 2 (participant2), ATTRID:  4

---------------------------------------------------------------------------

è  HEAP 파일은 삭제 마킹 되고 BTREE 파일은 삭제되어야 하나, 삭제된 클래스(UNKNOWN-CLASS 표시됨) 대한 BTREE 파일이 여전히 존재한다.

 

 

예시 5. checkdb 수행 시 오류 발생

$ cubrid checkdb -S testdb

 

CUBRID 2008 R1.4

 

Some inconsistencies were detected in your database.

 Please consult error_log_file /home1/brightest/CUBRID/log/server/testdb_20090304_1529.err for additional information.

 

 

예시 6. backupdb 수행 시 오류 발생

[brightest@cdbs006 testdb]$ cubrid backupdb -S testdb

 

CUBRID 2008 R1.4

 

Some inconsistencies were detected in your database.

 Please consult error_log_file /home1/brightest/CUBRID/log/server/testdb_20090304_1529.err for additional information.

 

 

예시 7. backupdb 수행 시 --no-check 옵션 추가

$ cubrid backupdb -S --no-check testdb

 

CUBRID 2008 R1.4

 

Backup Volume Label: Level: 0, Unit: 0, Database testdb, Backup Time: Wed Mar  4 15:29:49 2009

è  --no-check 옵션으로 정상동작함을 알 수 있다.

 


List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
279 운영관리 csql 데이터 입력방법 정만영 2009.06.09 213311
278 마이그레이션 CUBRID vs MySQL vs ORACLE SQL 타입별 비교 정만영 2013.07.12 69161
277 응용개발 weblogic 8.1 에 CUBRID Connection Pool, DataSource 설정 방법 file 웁쓰 2009.07.01 66306
276 응용개발 WHERE 조건에서 다중 컬럼 IN절 처리 최적화 방법 (cubrid + ibatis) 1 이상신 2015.08.21 55135
275 응용개발 Weblogic 10.0 사용시 JDK 1.5를 사용한 JDBC 드라이버 사용시 주의사항. cubebridge 2012.02.22 51957
274 마이그레이션 타 DBMS를 CUBRID로 마이그레이션 시 varchar,char 컬럼 사이즈 관련 손승일 2010.07.01 38024
273 질의작성 데이터 존재하면 update, 존재하지 않으면 insert 방법(ON DUPLICATE KEY UPDATE) 손승일 2010.08.11 37999
272 질의작성 예약어를 테이블명이나 컬럼명으로 사용시 admin 2008.11.21 37422
271 응용개발 JDBC 사용시 SQL 로깅 - p6spy 사용 1 웁쓰 2009.07.01 36001
270 기타 좀비 프로세스 일괄 삭제하기 janus 2009.12.12 34962
269 응용개발 CUBRID AUTO_INCREMENT 컬럼 MySQL LAST_INSERT_ID() 대체 방법 손승일 2009.12.22 33235
268 운영관리 CUBRID에서의 BLOB/CLOB 사용시 백업 및 복구에 대한 주의 점 cubebridge 2012.09.18 33157
267 마이그레이션 MySQL의 limit 명령어 처리 1 admin 2008.11.21 32685
266 CUBRID 매니저 Java SP사용시 JNI_CreateJavaVM 에러메시지 해결 방법 file seongjoon 2009.07.15 32043
265 응용개발 php에서 serialize/unserialize 사용 시 주의할 점 시난 2009.12.29 31628
264 운영관리 CUBRID 사용시 방화벽 설정 3 admin 2008.11.21 30996
263 마이그레이션 CUBRID 하위버젼에서 CUBRID2008로의 업그레이드 방법 1 남재우 2008.12.06 30154
262 운영관리 큐브리드 사용포트 정리 3 정만영 2009.06.19 29776
261 질의작성 CUBRID DB 내의 auto_increment 값을 초기화 하자. 손승일 2009.10.28 29732
260 응용개발 CUBRID와 Oracle에서의 ''(공백)의 차이 비교 cubebridge 2010.10.01 28583
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 14 Next
/ 14

Contact Cubrid

대표전화 070-4077-2110 / 기술문의 070-4077-2113 / 영업문의 070-4077-2112 / Email. contact_at_cubrid.com
Contact Sales