Sales 테이블에 복합키로 기본키를 구성하는 이유가 무엇인가요?
424
작성한 질문수 1
복합키로 기본키를 구성하는 이유가 궁금합니다.
seq 하나만 기본키로 잡았을때 장점이 더 많지 않나요?
답변 2
0
seq key는 dummy key라고 해서 의미를 갖지 않고 단지 식별을 위함이죠. 그럼 실제 같은 sales값이 들어와서 중복으로 등록도어도 막을 수가 없겠죠. 복합키는 중복을 원천적으로 학을 수 있죠. 둘다 사용해야 하는 경우가 다릅니다
0
안녕하세요, 인프런 AI 인턴입니다.
앙말굽띄님, 복합키로 기본키를 구성하는 주된 이유는 여러 필드의 조합으로 고유성을 보장하여 테이블 내의 각 레코드를 명확하게 식별하기 위해서입니다. 단일 필드로 구성된 기본키(seq와 같은)만 사용할 경우, 각 레코드가 고유함을 보장하기 힘들 수 있고, 비즈니스 규칙을 더 풍부하게 표현하는 데 한계가 있을 수 있습니다. 예를 들어, Sales 테이블에서는 판매 날짜, 제품 ID, 매장 ID 등 여러 필드의 조합을 통해 각 판매 이벤트의 고유성을 보장할 수 있습니다.
복합키를 사용하는 것과 단일 필드 기본키를 사용하는 것 사이에는 각각 장단점이 있습니다.
복합키의 장점:
- 데이터의 고유성과 함께 논리적인 연관성도 표현할 수 있습니다.
- 비즈니스 규칙이나 요구 사항을 데이터베이스 스키마에 직접적으로 반영할 수 있어서, 데이터의 무결성을 강화합니다.
- 데이터의 고유성과 함께 논리적인 연관성도 표현할 수 있습니다.
단일 필드 기본키의 장점:
- 기본키로 인덱스를 생성할 때, 단일 칼럼이므로 인덱스 관리가 더 간단하고 효율적일 수 있습니다.
- 데이터를 참조하는 외래키를 설정할 때 단일 칼럼만 사용하므로, 데이터 모델이 단순해지고 이해하기 쉽습니다.
- 기본키로 인덱스를 생성할 때, 단일 칼럼이므로 인덱스 관리가 더 간단하고 효율적일 수 있습니다.
따라서, 복합키를 선택하는지, 단일 필드를 기본키로 선택하는지는 어플리케이션의 비즈니스 요구사항, 데이터의 특성, 성능 요구 사항 등 다양한 요소를 고려하여 결정해야 합니다.
MySql
0
3
1
강사님.. 하단 URL에 있었던 코드들 다운 받거나 공유 부탁 드립니다..
0
4
1
팬텀리드 해결 예시 질문
0
13
0
강의 연장 요청
0
17
1
최신버젼 다운로드
0
19
2
차단 등 검증 로직의 위치
0
27
2
하단 파일이 열리지 않습니다
0
34
1
ssh-keygen -t rsa -P "" 등 ssh 암호화? 는 하둡에서 필수인가요?
0
27
2
일대일 fk 위치
0
30
1
GROUP BY, HAVING 실습 1번문제
1
28
2
수업에서 사용하는 툴 질문드려요
0
38
2
다음 강의는 언제쯤 나올까요?
0
48
2
땃지님 실습소 DB서버 확인 부탁드립니다
0
27
2
RootModel에 대한 질문
0
260
2
시 군 구로 나눈 이유가 궁금합니다.
0
369
2
인덱스 테이블에 대해서 질문이 있습니다.
0
407
2
1. stored procedure 는 언제 쓰면 좋은가요 ? / 2. 대댓글 테이블 설계
0
891
1
상품 테이블 설계에서 컬러, 사이즈 테이블의 PK 구성 질문
0
464
3
멀티 필터 select를 위한 설계
0
321
2
안녕하세요 SP_Sgg_Delete 프로시저 관련 질문드립니다.
0
316
2
테이블 설계관련 문의드려요
0
504
5
궁금중 여쭤봅니다.
0
309
1
SP_Sgg_Add 관련 문의드립니다.
0
204
1
코드 업로드 해주실 수 있으신가요?
0
386
3





