inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

RDBMS Modeling 실습

고객 테이블

Sales 테이블에 복합키로 기본키를 구성하는 이유가 무엇인가요?

424

앙말굽띄

작성한 질문수 1

0

복합키로 기본키를 구성하는 이유가 궁금합니다.

seq 하나만 기본키로 잡았을때 장점이 더 많지 않나요?

oracle dbms/rdbms mssql 데이터-엔지니어링

답변 2

0

이교준

seq key는 dummy key라고 해서 의미를 갖지 않고 단지 식별을 위함이죠. 그럼 실제 같은 sales값이 들어와서 중복으로 등록도어도 막을 수가 없겠죠. 복합키는 중복을 원천적으로 학을 수 있죠. 둘다 사용해야 하는 경우가 다릅니다

0

인프런 AI 인턴

안녕하세요, 인프런 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