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 옵션으로 정상동작함을 알 수 있다.

 


  1. JAVA SP를 통해 다른 데이터베이스 연결하는 경우 잊지 말자.

    Date2009.12.16 Category응용개발 By손승일 Views17975
    Read More
  2. CUBRID 설치 서버의 OS bit 확인하는 방법과 CUBRID bit 확인 방법.

    Date2009.12.15 Category기타 Byseongjoon Views18961
    Read More
  3. 좀비 프로세스 일괄 삭제하기

    Date2009.12.12 Category기타 Byjanus Views34917
    Read More
  4. 한 개 PC에서 CUBRID7.3과 CUBRID2008R1.4 & R2.0 매니저 사용 방법

    Date2009.12.12 CategoryCUBRID 매니저 By정만영 Views13054
    Read More
  5. CUBRID2008 파티션 테이블 삭제 시 인덱스 drop 안 되는 현상 예시

    Date2009.12.12 Category운영관리 Bycubebridge Views18461
    Read More
  6. CUBRID 복제 구성 시 Update id=id+1 미지원

    Date2009.12.12 Category운영관리 Bycubebridge Views11651
    Read More
  7. CUBRID제거 절차

    Date2009.12.12 Category운영관리 Byjanus Views15888
    Read More
  8. 리눅스 쉘프롬프트 상에서 질의 바로 수행하기

    Date2009.12.10 Category운영관리 ByPrototype Views13640
    Read More
  9. CUBRID 2008 R2.0 RPM 설치후 PHP모듈 로딩에 실패할 경우

    Date2009.12.10 Category운영관리 ByPrototype Views14918
    Read More
  10. CUBRID odbc 드라이버 설정방법.

    Date2009.12.10 Category응용개발 Byseongjoon Views20327
    Read More
  11. CUBRID 예약어 사용방법

    Date2009.12.09 Category질의작성 By정만영 Views17183
    Read More
  12. 64비트 윈도우환경에서 32비트 ODBC 사용하기

    Date2009.12.09 Category운영관리 ByPrototype Views22676
    Read More
  13. 시스템 테이블을 이용한 인덱스 생성 구문 만들기

    Date2009.12.02 Category질의작성 Byjanus Views15143
    Read More
  14. 예제를 이용한 중복데이터 삭제

    Date2009.12.02 Category질의작성 Byjanus Views18541
    Read More
  15. CUBRID JAVA Stored Procedure의 GC로그 출력방법

    Date2009.12.01 Category운영관리 Byjanus Views15315
    Read More
  16. CUBRID LOCK 관련 오류(ERROR CODE = -75) 정리

    Date2009.12.01 Category운영관리 By정만영 Views20675
    Read More
  17. 각 데이터베이스에 개별적 파라미터 적용하는 방법

    Date2009.11.30 Category운영관리 By정만영 Views10182
    Read More
  18. 브로커 상태를 확인할 때 status 의미

    Date2009.11.27 Category운영관리 By시난 Views16552
    Read More
  19. PHP에서 Prepared statement 사용시 NULL 값을 바인딩 하는 방법

    Date2009.11.27 Category응용개발 ByPrototype Views19722
    Read More
  20. CUBRID 복제중인 DB 백업 중 아카이브 로그파일 삭제 방법

    Date2009.11.26 Category운영관리 By손승일 Views17159
    Read More
Board Pagination Prev 1 ... 4 5 6 7 8 9 10 11 12 13 14 Next
/ 14

Contact Cubrid

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