식별자 구분 (대체 여부에 따라)
- 본질식별자
- 업무에 의해 만들어지는 식별자 (꼭 필요한 식별자)
- 인조식별자
- 인위적으로 만들어지는 식별자 (꼭 필요하지 않지만 관리의 편이성 등의 이유로 만들어지는 식별자)
- 본질식별자가 복잡한 구성을 가질 때 인위적으로 생성
- 주로 각 행을 구분하기 위한 기본키로 사용되며, 자동으로 증가하는 일련번호 같은 형태
예) 주문과 주문 상세에 대한 엔티티 설계 과정
주문이 들어오면 주문 엔티티에는 (주문번호 + 고객번호)를 저장, 이때 PK는 주문번호
주문상세에는 각 주문별로 어떤 상품이, 언제, 몇 개 주문됐는지 등을 기록
주문상세 테이블 설계 시 다음과 같은 식별자를 고려할 수 있음
1. PK : 주문번호 + 상품번호
- 주문을 하면 주문번호와 상품번호가 필요하므로 본질식별자 (주문번호 + 상품번호)가 됨
- 하지만 하나의 주문번호로 같은 상품의 주문 결과를 저장할 수 없게 됨
- 동일한 장바구니에 A 상품을 5개 주문했는데, 뒤에 또 다시 A 상품을 3개 추가로 주문하는 경우 불가능
2. PK : 주문번호 + 주문순번 (주문순번이라는 컬럼 생성)
- 하나의 주문에 여러 상품에 대한 주문 결과 저장 가능 → 주문순번으로 인해 구분함
- 매 주문마다 동일한 상품 주문 시 주문순번을 정하기 위해 상품의 주문 횟수를 세어야한다는 점이 매우 불편!
- 사과를 총 3번 구매 ≫ 주문순번은 1, 2, 3 순서대로 입력돼야 함
3. PK : 주문상세번호 (인조식별자 생성)
- 주문상세번호로 각 주문이력을 구분
- 같은 주문의 같은 상품이력이 저장될 수 있음
- 주문상세번호만이 주식별자 ≫ 나머지 정보들이 불필요하게 중복 저장될 위험 발생
- 실제 업무와 상관없는 주문상세번호를 주식별자로 생성하면 쓸모없는 index가 생성됨 (PK 생성 시 자동 unique index 생성)
** 인조식별자의 단점
- 중복 데이터 발생 가능성 ≫ 데이터 품질 저하
- 불필요한 인덱스 생성 ≫ 저장공간 낭비 및 DML 성능 저하
인덱스 (INDEX)
조회 성능을 향상시키기 위한 객체
인덱스는 DML (INSERT/UPDATE/DELETE) 시 INDEX SPLIT 현상으로 인해 성능이 저하됨
'sqld' 카테고리의 다른 글
2-2) SELECT 문 (0) | 2024.08.20 |
---|---|
2-1) 관계형 데이터베이스 개요 (0) | 2024.08.19 |
1-9) Null 속성의 이해 (0) | 2024.08.19 |
1-8) 모델이 표현하는 트랜잭션의 이해 (0) | 2024.08.19 |
1-7) 관계와 조인의 이해 (0) | 2024.08.19 |