information_schema
MariaDB, MySQL information_schema 데이터베이스는 데이터베이스 메타데이터를 저장하는 시스템 데이터베이스입니다.
주요 특징
- 읽기 전용 데이터베이스로, 사용자가 직접 수정할 수 없습니다.
- 현재 데이터베이스 서버의 모든 데이터베이스, 테이블, 컬럼, 인덱스 등에 관한 정보를 포함합니다.
- MySQL과 호환되지만 MariaDB만의 고유한 테이블들도 있습니다.
주요 테이블
- TABLES: 모든 테이블에 관한 정보
- COLUMNS: 모든 컬럼에 관한 정보
- SCHEMATA: 데이터베이스(스키마)에 관한 정보
- STATISTICS: 인덱스에 관한 정보
- USER_PRIVILEGES: 사용자 권한에 관한 정보
- TABLE_CONSTRAINTS: 제약조건에 관한 정보
- ROUTINES: 저장 프로시저와 함수에 관한 정보
- TRIGGERS: 트리거에 관한 정보
- VIEWS: 뷰에 관한 정보
예시
information_schema를 활용한 예시 쿼리 입니다.
-- 모든 데이터베이스 목록 조회
SELECT schema_name FROM information_schema.SCHEMATA;
-- 특정 데이터베이스의 모든 테이블 조회
SELECT table_name FROM information_schema.TABLES
WHERE table_schema = '데이터베이스명';
-- 특정 테이블의 모든 컬럼 정보 조회
SELECT column_name, data_type, character_maximum_length
FROM information_schema.COLUMNS
WHERE table_schema = '데이터베이스명' AND table_name = '테이블명';
주요컬럼
가장 많이 사용하는 information_schema.tables의 컬럼들 설명 입니다.
- TABLE_CATALOG: 카탈로그 이름 (MariaDB에서는 주로 'def' 값을 가짐)
- TABLE_SCHEMA: 테이블이 속한 데이터베이스(스키마) 이름
- TABLE_NAME: 테이블 이름
- TABLE_TYPE: 테이블 유형 ('BASE TABLE', 'VIEW', 'SYSTEM VIEW' 등)
- ENGINE: 테이블에 사용된 스토리지 엔진 (InnoDB, MyISAM 등)
- VERSION: 테이블의 버전 정보
- ROW_FORMAT: 행 저장 포맷 (Fixed, Dynamic, Compressed 등)
- TABLE_ROWS: 테이블의 대략적인 행 수 (정확한 값이 아닌 추정치)
- AVG_ROW_LENGTH: 평균 행 길이 (바이트)
- DATA_LENGTH: 데이터 파일의 크기 (바이트)
- MAX_DATA_LENGTH: 데이터 파일의 최대 크기
- INDEX_LENGTH: 인덱스 파일의 크기 (바이트)
- DATA_FREE: 할당되었지만 사용되지 않는 바이트 수
- AUTO_INCREMENT: 현재 AUTO_INCREMENT 값
- CREATE_TIME: 테이블이 생성된 시간
- UPDATE_TIME: 테이블이 마지막으로 업데이트된 시간
- CHECK_TIME: 테이블이 마지막으로 체크된 시간
- TABLE_COLLATION: 테이블의 문자 정렬 방식
- CHECKSUM: 테이블 체크섬 값
- CREATE_OPTIONS: 테이블 생성 시 사용된 옵션들
- TABLE_COMMENT: 테이블에 대한 코멘트나 설명

'프로그래밍언어 > DB, SQL' 카테고리의 다른 글
| DBeaver 주요 단축키 (0) | 2025.04.02 |
|---|---|
| SQL 기본 튜닝 규칙 - PostgreSQL (0) | 2024.07.08 |
| PostgreSQL 프로시저 (0) | 2024.06.16 |
| 디비버 많이 쓰는 단축키 (0) | 2024.05.30 |
| 무료 DB관리툴 디비버 (0) | 2024.04.30 |
댓글