클러스터 인덱스, 넌클러스터 인덱스 (Clustered Index)

2024. 3. 29. 15:12·DB
728x90

인덱스

  • 인덱스는 DB의 테이블에 데이터가 많을 때, 검색 속도를 향상시켜주기위해 사용하는 객체
  • 컬럼을 정렬한 후에 데이터를 빠르게 찾을 수 있도록 도와주는 역할

 

클러스터 인덱스

  • 테이블에 클러스터 인덱스를 적용할 때마다 그 테이블에 정렬 작업이 수반됨
  • 클러스터 인덱스는 Primary Key처럼 한 테이블에 한 개만 생성할 수 있음
  • 클러스터 인덱스는 데이터를 가리키는 포인터가 아닌 데이터를 저장한 블록의 포인터를 저장

 

넌클러스터 인덱스

  • 비 클러스터 인덱스는 책의 색인(Index)과 같은 역할
  • 데이터와 인덱스는 각각 다른 장소에 저장되므로 한 테이블에 여러 개의 비 클러스터 인덱스를 생성할 수 있음
  • 데이터를 가리키는 포인터를 저장

 

예시

  • id를 PK로 지정하여 id의 순서에 따라 정렬됨
  • email에 넌클러스트인덱스를 지정하여 email컬럼으로 검색을 빠르게 할 수 있음

 

책에 비유하자면
클러스터 인덱스는 페이지를 알기 때문에 바로 그 페이지를 펴는 것
넌클러스터 인덱스는 뒤에 목차에서 찾고자 하는 내용의 페이지를 찾고 그 페이지로 이동하는 것
테이블 스캔은 처음부터 한 장씩 넘기면서 내용을 찾는 것

 

  Clustered Nonclustered
사용 기록을 정렬하고 저장할 수 있음
cluster순서에 따라
물리적으로 메모리에 인덱스를 추가
데이터 행의 논리적 순서를 생성하는 데 도움됨
실제 데이터 파일에 대한 포인터를 사용
보관방법 인덱스의 리프 노드에 데이터 페이지를 저장 인덱스의 리프 노드에 데이터 페이지를 저장하지 않음
크기 큼 상대적 작음
데이터 액세스 빠름 상대적 느림
추가 디스크 공간 필요하지 않음 인덱스를 별도로 저장해야 함
키 유형 기본적으로 테이블의 기본 키 복합 키 역할을 하는 테이블에 대한 고유 제약 조건과 함께
사용할 수 있음
주요 특징 데이터 검색 성능을 향상시킬 수 있음 조인에 사용되는 열에 생성되어야 함

 

 

728x90
'DB' 카테고리의 다른 글
  • [graphDB] 그래프 DB, Neo4j , Amazon Neptune
  • [Elasticsearch] 설치 및 Index, Document 생성
  • [Redis] Redis 설치 및 기본 명령어
Karla Ko
Karla Ko
𝘾𝙤𝙣𝙩𝙞𝙣𝙪𝙤𝙪𝙨𝙡𝙮 𝙄𝙢𝙥𝙧𝙤𝙫𝙞𝙣𝙜, 𝘾𝙤𝙣𝙨𝙩𝙖𝙣𝙩𝙡𝙮 𝘿𝙚𝙫𝙚𝙡𝙤𝙥𝙞𝙣𝙜 𝙔𝙚𝙨!
    250x250
  • Karla Ko
    karlaLog
    Karla Ko
  • 전체
    오늘
    어제
    • Total (467)
      • Spring (19)
      • JPA (4)
      • Cloud & Architecture (15)
        • Kubernetes (5)
        • Docker (3)
        • MSA (2)
        • GCP (1)
        • AWS (4)
      • Devops (1)
      • Message Queue (4)
        • Kafka (2)
        • RabbitMQ (2)
      • Git (4)
      • DB (4)
      • Java (9)
      • Python (4)
      • CS (11)
        • OS (8)
        • Network (2)
        • Algorithm (1)
      • Coding Test (392)
        • programmers (156)
        • Graph (43)
        • DP (37)
        • Search (31)
        • Tree (13)
        • Data Structure (26)
        • Combination (12)
        • Implement (18)
        • Geedy (23)
        • Sort (7)
        • Math (21)
        • geometry (2)
  • 블로그 메뉴

    • 홈
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    파이썬
    자료구조
    그리디
    덱
    트리
    최소신장트리
    최단거리
    LIS
    월간코드챌린지
    정렬
    스택
    다익스트라
    구간합
    재귀
    동적계획법
    알고리즘
    백준
    DP
    BFS
    플로이드워셜
    구현
    그래프
    큐
    Algorithm
    DFS
    최대공약수
    힙
    조합
    이분탐색
    프로그래머스
  • hELLO· Designed By정상우.v4.10.3
Karla Ko
클러스터 인덱스, 넌클러스터 인덱스 (Clustered Index)
상단으로

티스토리툴바