Background Image
질의작성
2015.12.08 00:31

테이블 용량 산정 쿼리

조회 수 7398 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
데이터 베이스를 관리 하다보면 현재 테이블의 스키마 정보를 토대로 
각 테이블 별 ROW 사이즈 및 용량을 산정하기 위한 작업이 필요할 때가 있다.

이때 편리하게 용량 산정을 위한 쿼리를 생각해 보았다.
테이블명, 컬럼수, 실제_스키마_ROW_사이즈(byte)가 기본 정보이며
특정 컬럼이 테이블 ROW 사이즈를 많이 잡아 먹는지에 대한 추가정보(예제에는 100 PREC 이상)
와 파티션이 된 테이블인지와 파티션 컬럼이 무었인지 확인 하게 되어 있다.

SELECT 
c.class_name,
COUNT(*) AS count_column,
CAST(SUM(CASE
WHEN "data_type" = 'BIGINT' THEN 8.0
WHEN "data_type" = 'INTEGER' THEN 4.0
WHEN "data_type" = 'SMALLINT' THEN 2.0
WHEN "data_type" = 'FLOAT' THEN 4.0
WHEN "data_type" = 'DOUBLE' THEN 8.0
WHEN "data_type" = 'MONETARY' THEN 12.0
WHEN "data_type" = 'STRING' THEN a.prec
WHEN "data_type" = 'VARCHAR' THEN a.prec
WHEN "data_type" = 'NVARCHAR' THEN a.prec
WHEN "data_type" = 'CHAR' THEN a.prec
WHEN "data_type" = 'NCHAR' THEN a.prec
WHEN "data_type" = 'TIMESTAMP' THEN 8.0
WHEN "data_type" = 'DATE' THEN 4.0
WHEN "data_type" = 'TIME' THEN 4.0
WHEN "data_type" = 'DATETIME' THEN 4.0
WHEN "data_type" = 'BIT' THEN FLOOR(prec / 8.0)
WHEN "data_type" = 'BIT VARYING' THEN FLOOR(prec / 8.0)
ELSE 0
END) AS BIGINT) AS [size_column(byte)],
SUM(CASE
WHEN "data_type" = 'STRING' THEN 1
WHEN "data_type" = 'VARCHAR' THEN 1
WHEN "data_type" = 'NVARCHAR' THEN 1
WHEN "data_type" = 'NCHAR' THEN 1
WHEN "data_type" = 'BIT VARYING' THEN 1
ELSE 0
END) AS count_size_over_column,
v.cols AS size_over_columns,
MAX(c.partitioned) AS partitioned,
CONCAT(MAX(p.partition_type), MAX(p.partition_expr)) AS partition_info
FROM
db_class c 
JOIN db_attribute a ON a.class_name = c.class_name AND a.from_class_name IS NULL
LEFT JOIN db_partition p ON p.class_name = a.class_name
LEFT JOIN (
SELECT class_name, GROUP_CONCAT(cols) AS cols
FROM (
SELECT class_name, CONCAT(attr_name,' ', [data_type], '(', prec,')') AS cols 
FROM db_attribute
WHERE [data_type] IN ('STRING', 'VARCHAR', 'NVARCHAR', 'NCHAR', 'BIT VARYING')
AND prec >= 100
) z
GROUP BY class_name
) v ON v.class_name = a.class_name
WHERE
c.is_system_class = 'NO'
AND c.class_type = 'CLASS'
AND c.class_name <> '_cub_schema_comments'
GROUP BY
c.class_name,
v.cols;

위의 예제 쿼리로 CUBRID 설치 시 demodb의 ROW 사이즈별 용량은 다음과 같다.

class_name

count_column

size_column(byte)

count_size_over_column 

partitioned 

partition_info

 

 

 athlete

 5

 78

 2

 

 NO

 

 

 code

 3

 7

 1

 

 NO

 

 

 event

 5

 109

 2

 

 NO

 

 

 game

 7

 24

 0

 

 NO

 

 

 history

 5

 63

 3

 

 NO

 

 

 nation

 4

 83

 3

 

 NO

 

 

 olympic

 8

 1632

 5

 introduction STRING(1500)

 NO

 

 

 participant

 5

 19

 0

 

 NO

 

 

 record

 6

 38

 2

 

 NO

 

 

 stadium

 6

 161

 2

 address STRING(100)

 NO

 

 



  1. MySQL 테이블 크기 조사하기-공유

    Date2015.12.31 Category마이그레이션 By주현 Views6203
    Read More
  2. CUBRID BACKUP (linux, window)

    Date2015.12.30 Category운영관리 By박동윤 Views6244
    Read More
  3. Cubrid는 어떤 쿼리를 동일한 쿼리로 판단할까?

    Date2015.12.30 Category질의작성 By이상신 Views4010
    Read More
  4. 브로커와 DB 간 연결 테스트

    Date2015.12.29 Category운영관리 By박동윤 Views4934
    Read More
  5. CUBRID HA 제약 사항 및 확인 방법

    Date2015.12.29 Category응용개발 By손승일 Views5304
    Read More
  6. cubrid plandump ( plan cache정보확인)

    Date2015.12.29 Category운영관리 By주현 Views4300
    Read More
  7. CUBRID와 Oracle의 NULL과 '' (empty string)의 처리 차이점

    Date2015.12.29 Category마이그레이션 By권호일 Views15416
    Read More
  8. CM(CUBRID Manager)을 이용하여 행정표준코드시스템의 기관코드 가져오기

    Date2015.12.28 Category마이그레이션 By권호일 Views6329
    Read More
  9. 테이블 명세서 한 시트로 합치기

    Date2015.12.24 CategoryCUBRID 매니저 By성진 Views16523
    Read More
  10. 일정 범위 임의의 정수 생성 방법(random 함수 응용)

    Date2015.12.22 Category질의작성 By손승일 Views6471
    Read More
  11. 시스템 부하가 많지 않음에도 불구하고 질의 수행이 느린 경우 THP 기능 설정 확인 및 해제

    Date2015.12.16 Category운영관리 By진우진 Views7525
    Read More
  12. 큐브리드 서비스 재구동 시 cubrid manager server start: fail 오류 해결 방법

    Date2015.12.16 Category운영관리 By진우진 Views7730
    Read More
  13. maven에서 CUBRID JDBC Driver 추가하기

    Date2015.12.09 Category응용개발 By김승훈 Views8933
    Read More
  14. 오라클의 DBMS_RANDOM.STRING() 함수를 CUBRID 식으로 구현하는 방법

    Date2015.12.08 Category질의작성 By이경오 Views7972
    Read More
  15. 테이블 용량 산정 쿼리

    Date2015.12.08 Category질의작성 By성진 Views7398
    Read More
  16. WHERE 조건에서 다중 컬럼 IN절 처리 최적화 방법 (cubrid + ibatis)

    Date2015.08.21 Category응용개발 By이상신 Views55127
    Read More
  17. 브로커 동적 파라미터 변경 방법

    Date2015.08.13 Category운영관리 By정만영 Views7566
    Read More
  18. 전체 테이블 UPDATE시 SELECT, UPDATE를 통한 INDEX SCAN방식으로 테이블 X_LOCK을 방지하자!

    Date2015.08.13 Category질의작성 By이경오 Views13793
    Read More
  19. CUBRID HA 구성 후 구동중인 slave/replica node에서 write 하기

    Date2015.07.15 Category운영관리 By정만영 Views9043
    Read More
  20. INSERT수행 시, 현재날짜,현재시각으로 자동 입력하는 방법

    Date2015.07.08 Category질의작성 By주현 Views25198
    Read More
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