Oracle Partitioning은 대용량 테이블과 인덱스를 여러 개의 파티션으로 나누어 관리하는 기술입니다. 이를 통해 쿼리 성능 향상, 병렬 처리 최적화, 관리 용이성 개선 등의 장점을 제공합니다.
Oracle에서는 여러 가지 파티션 방식을 제공하며, 데이터의 분할 기준에 따라 나뉩니다.
📌 예제: 주문일(order_date)을 기준으로 분할
CREATE TABLE orders (
order_id NUMBER,
customer_id NUMBER,
order_date DATE,
amount NUMBER
)
PARTITION BY RANGE (order_date) (
PARTITION p_2023 VALUES LESS THAN (TO_DATE('2024-01-01', 'YYYY-MM-DD')),
PARTITION p_2024 VALUES LESS THAN (TO_DATE('2025-01-01', 'YYYY-MM-DD'))
); p_2023: 2023년까지의 주문 데이터 저장p_2024: 2024년 주문 데이터 저장✔ 장점:
📌 예제: 국가(region)를 기준으로 파티션 분할
CREATE TABLE customers (
customer_id NUMBER,
customer_name VARCHAR2(100),
region VARCHAR2(50)
)
PARTITION BY LIST (region) (
PARTITION p_korea VALUES ('KOREA'),
PARTITION p_usa VALUES ('USA'),
PARTITION p_others VALUES (DEFAULT)
); p_korea: 한국 데이터 저장p_usa: 미국 데이터 저장p_others: 그 외 국가 데이터 저장✔ 장점:
📌 예제: 고객 ID를 기준으로 해시 파티션 적용
CREATE TABLE transactions (
transaction_id NUMBER,
customer_id NUMBER,
amount NUMBER
)
PARTITION BY HASH (customer_id)
PARTITIONS 4; ✔ 장점:
📌 예제: 연도별(RANGE) + 고객 ID(HASH) 복합 파티션 적용
CREATE TABLE sales (
sale_id NUMBER,
sale_date DATE,
customer_id NUMBER,
amount NUMBER
)
PARTITION BY RANGE (sale_date)
SUBPARTITION BY HASH (customer_id)
SUBPARTITIONS 4 (
PARTITION p_2023 VALUES LESS THAN (TO_DATE('2024-01-01', 'YYYY-MM-DD')),
PARTITION p_2024 VALUES LESS THAN (TO_DATE('2025-01-01', 'YYYY-MM-DD'))
);
연도별로 1차 분할 (RANGE)
HASH)✔ 장점:
Partition Pruning(파티션 절단)은 불필요한 파티션을 자동으로 제외하여 성능을 최적화하는 기법입니다.
쿼리에서 특정 조건을 포함하면 해당 파티션만 접근하여 I/O 부하를 줄일 수 있음.
SELECT * FROM orders WHERE order_date BETWEEN TO_DATE('2024-01-01', 'YYYY-MM-DD')
AND TO_DATE('2024-12-31', 'YYYY-MM-DD'); ✔ 결과:
p_2024 파티션만 읽고, 다른 파티션(p_2023 등)은 읽지 않음 → I/O 최소화SELECT * FROM customers WHERE region = 'KOREA'; ✔ 결과:
p_korea 파티션만 접근 → 성능 향상SELECT * FROM transactions WHERE customer_id = 12345; ✔ 결과:
customer_id 해시 값에 따라 특정 파티션에만 접근 → 랜덤 분산에도 불필요한 I/O 최소화ALTER TABLE orders ADD PARTITION p_2025 VALUES LESS THAN (TO_DATE('2026-01-01', 'YYYY-MM-DD')); ALTER TABLE orders DROP PARTITION p_2023; ALTER TABLE orders MERGE PARTITIONS p_2023, p_2024 INTO PARTITION p_merged; ALTER TABLE orders TRUNCATE PARTITION p_2023; ✅ Oracle Partitioning은 대량 데이터의 효율적인 관리와 성능 최적화에 필수적인 기술
✅ 프루닝을 통해 쿼리 속도를 대폭 향상 가능
✅ RANGE, LIST, HASH, COMPOSITE 등의 파티션 기법을 적절히 활용하여 성능 개선 가능
✅ 불필요한 데이터 관리(삭제, 이동)도 쉽게 수행 가능
🎯 대용량 데이터 처리 및 분석 업무에서 반드시 고려해야 할 핵심 기술! 🚀
1. 타입스크립트 개요 타입스크립트(TypeScript)는 마이크로소프트(Microsoft)가 개발한 자바스크립트(JavaScript)의 상위 집합(Superset) 언어입니다.즉, 자바스크립트에 정적 타입(Static Type)을 추가하고,…
윈도우 운영체제의 노트북에서는 iPhone 유선 테더링이 잘 안되는 경우가 많습니다. 보통 iPhone의 드라이버가 설치가 안되있어서인…
안녕하세요, 혹시 이런 생각해 본 적 없으신가요? "내가 투자한 회사는 누가 감시하고, 어떻게 운영될까?" 오늘은…
1. Gemini CLI란 무엇인가요? Gemini CLI는 터미널 환경에서 직접 Gemini 모델과 상호작용할 수 있도록 만들어진…