Sales 테이블에 복합키로 기본키를 구성하는 이유가 무엇인가요?
444
1 asked
복합키로 기본키를 구성하는 이유가 궁금합니다.
seq 하나만 기본키로 잡았을때 장점이 더 많지 않나요?
Answer 2
0
seq key는 dummy key라고 해서 의미를 갖지 않고 단지 식별을 위함이죠. 그럼 실제 같은 sales값이 들어와서 중복으로 등록도어도 막을 수가 없겠죠. 복합키는 중복을 원천적으로 학을 수 있죠. 둘다 사용해야 하는 경우가 다릅니다
0
안녕하세요, 인프런 AI 인턴입니다.
앙말굽띄님, 복합키로 기본키를 구성하는 주된 이유는 여러 필드의 조합으로 고유성을 보장하여 테이블 내의 각 레코드를 명확하게 식별하기 위해서입니다. 단일 필드로 구성된 기본키(seq와 같은)만 사용할 경우, 각 레코드가 고유함을 보장하기 힘들 수 있고, 비즈니스 규칙을 더 풍부하게 표현하는 데 한계가 있을 수 있습니다. 예를 들어, Sales 테이블에서는 판매 날짜, 제품 ID, 매장 ID 등 여러 필드의 조합을 통해 각 판매 이벤트의 고유성을 보장할 수 있습니다.
복합키를 사용하는 것과 단일 필드 기본키를 사용하는 것 사이에는 각각 장단점이 있습니다.
복합키의 장점:
- 데이터의 고유성과 함께 논리적인 연관성도 표현할 수 있습니다.
- 비즈니스 규칙이나 요구 사항을 데이터베이스 스키마에 직접적으로 반영할 수 있어서, 데이터의 무결성을 강화합니다.
- 데이터의 고유성과 함께 논리적인 연관성도 표현할 수 있습니다.
단일 필드 기본키의 장점:
- 기본키로 인덱스를 생성할 때, 단일 칼럼이므로 인덱스 관리가 더 간단하고 효율적일 수 있습니다.
- 데이터를 참조하는 외래키를 설정할 때 단일 칼럼만 사용하므로, 데이터 모델이 단순해지고 이해하기 쉽습니다.
- 기본키로 인덱스를 생성할 때, 단일 칼럼이므로 인덱스 관리가 더 간단하고 효율적일 수 있습니다.
따라서, 복합키를 선택하는지, 단일 필드를 기본키로 선택하는지는 어플리케이션의 비즈니스 요구사항, 데이터의 특성, 성능 요구 사항 등 다양한 요소를 고려하여 결정해야 합니다.
19강 15_2) 템블릿에 List가 없는경우는 어떻게 해야되나요?
0
8
1
vercel실행 - failed to fetch
0
12
1
dags_email_on_failure
0
13
1
15강 12-3) 값 제출후 mysql 저장이 안됩니다.
0
13
2
드랍 테이블로 지운 ordes에 대해서 질문
0
23
1
문제 풀이 1번 질문
0
28
1
아주 작은 정오표 전달드립니다.
0
52
2
mysql워크벤치를 실행할때마다 오류가 뜹니다. 해결 방법좀 가르켜주세요.
0
44
1
DAG 실습 - dags_bash_operator 실행 실패
0
31
3
온톨로지 구축
0
27
1
실제로 작은 기업에서 기획 롤
1
27
1
함수기반 인덱스
0
30
2
날짜 인덱스관련 질문
0
26
1
RootModel에 대한 질문
0
271
2
시 군 구로 나눈 이유가 궁금합니다.
0
383
2
인덱스 테이블에 대해서 질문이 있습니다.
0
415
2
1. stored procedure 는 언제 쓰면 좋은가요 ? / 2. 대댓글 테이블 설계
0
900
1
상품 테이블 설계에서 컬러, 사이즈 테이블의 PK 구성 질문
0
473
3
멀티 필터 select를 위한 설계
0
329
2
안녕하세요 SP_Sgg_Delete 프로시저 관련 질문드립니다.
0
322
2
테이블 설계관련 문의드려요
0
523
5
궁금중 여쭤봅니다.
0
314
1
SP_Sgg_Add 관련 문의드립니다.
0
210
1
코드 업로드 해주실 수 있으신가요?
0
391
3

