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

 

 



List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
239 질의작성 입력된 년월 또는 두개의 날짜을 이용하여 달력 및 주차 구하기 1 성진 2016.08.10 5581
238 질의작성 입력된 날자를 이용하여 해당 주차의 모든 날자 구하기 성진 2018.04.10 1112
237 질의작성 임의의 컬럼을 rownum 으로 업데이트 하기 Prototype 2009.07.01 22536
236 질의작성 일정 범위 임의의 정수 생성 방법(random 함수 응용) 손승일 2015.12.22 6472
235 응용개발 응용프로그램에서 질의 처리시 commit/rollback 처리 문제 admin 2008.11.21 21600
234 응용개발 윈도우 환경에서 PHP 모듈 로드를 못 할 경우 해결법 3 Prototype 2009.11.26 22488
233 운영관리 윈도우 OS에서 java sp 사용 시 Java VM is not running 해결 방법 정훈 2017.09.04 2232
232 CUBRID 매니저 워크스페이스 사용중입니다. 다른 워크스페이스를 선택하세요. 대응법 성진 2015.04.24 10507
231 응용개발 용량이 큰 데이터를 질의로 저장하는 방법 남재우 2009.11.26 12117
230 질의작성 요일 값을 반환 받을 수 있는 질의 형태 정만영 2009.03.13 17108
229 질의작성 오류데이타검증 - 숫자 이외의 데이타 확인하는 방법 권호일 2013.01.17 21121
228 마이그레이션 오라클의 order by 시 first와 last 대체 사용법 file cubebridge 2012.11.12 20576
227 질의작성 오라클의 order by 시 first와 last 대체 사용법 file 이용미 2011.12.22 20178
226 질의작성 오라클의 DBMS_RANDOM.STRING() 함수를 CUBRID 식으로 구현하는 방법 이경오 2015.12.08 7974
225 질의작성 오라클 바이딩 변수와 큐브리드 인터프리터 변수를 사용한 경로 표현식 정만영 2009.06.09 13483
224 응용개발 오라클 to CUBRID로 마이그레이션 수행 시 주의사항 cubebridge 2012.11.12 16642
223 마이그레이션 오라클 to CUBRID로 마이그레이션 수행 시 주의사항 정만영 2012.03.02 21057
222 질의작성 예제를 이용한 중복데이터 삭제 janus 2009.12.02 18541
221 질의작성 예약어를 테이블명이나 컬럼명으로 사용시 admin 2008.11.21 37429
220 질의작성 여러건의 코드명을 한건으로 조회하는 쿼리입니다. 1 권호일 2012.03.30 10756
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