핵심 인사이트 (3줄 요약)
- 본질: 매핑 규칙은 개념 설계의 ERD(엔터티·관계·속성)를 논리 설계의 **릴레이션 스키마(테이블·PK·FK·컬럼)**로 변환하는 체계적 규칙 집합이다.
- 가치: 규칙 없이 직감으로 변환하면 관계 누락·PK 오류·중복 테이블이 발생하므로, 7대 매핑 규칙을 순서대로 적용하여 정확한 릴레이션을 도출한다.
- 판단 포인트: 1:1, 1:N, M:N 관계의 변환 방식이 각각 다르며, M:N → 교차 테이블 생성, 다치 속성 → 별도 테이블 분리, 약한 엔터티 → 소유자 FK 포함 복합 PK를 정확히 적용해야 한다.
Ⅰ. 개요 및 필요성
┌───────────────────────────────────────────────────────┐
│ 7대 매핑 규칙 순서 │
├───────────────────────────────────────────────────────┤
│ 1. 강한 엔터티 → 테이블 (PK = 식별자) │
│ 2. 약한 엔터티 → 테이블 (PK = 소유자FK + 부분키) │
│ 3. 1:1 관계 → 한쪽 테이블에 FK 추가 │
│ 4. 1:N 관계 → N쪽 테이블에 FK 추가 │
│ 5. M:N 관계 → 교차 테이블 생성 (양쪽 PK가 복합키) │
│ 6. 다치 속성 → 별도 테이블 분리 │
│ 7. N-ary 관계 → 관계 테이블 생성 │
└───────────────────────────────────────────────────────┘
- 📢 섹션 요약 비유: 매핑 규칙은 외국어 번역 문법이다. "주어+동사+목적어" 순서를 지키지 않으면 엉뚱한 문장(잘못된 스키마)이 나온다.
Ⅱ. 아키텍처 및 핵심 원리
관계 유형별 매핑
| 관계 | 매핑 방식 | 예시 |
| 1:1 | 한쪽에 FK (가능하면 전참여 쪽) | 사원←→여권 |
| 1:N | N쪽에 FK | 부서←→사원 |
| M:N | 교차 테이블 | 학생←→과목 → 수강(학생ID, 과목ID) |
| 약한 엔터티 | 소유자 FK + 부분키 = 복합 PK | 주문←→주문상세 |
| 다치 속성 | 별도 테이블 + FK | 사원(취미) → 취미(사원ID, 취미명) |
- 📢 섹션 요약 비유: M:N 관계는 학생과 과목이 서로 "누가 누구를 듣는지" 모르므로, **수강 기록부(교차 테이블)**를 만들어 연결하는 것이다.
Ⅲ. 비교 및 연결
| 비교 | 1:1 | 1:N | M:N |
| FK 위치 | 한쪽 | N쪽 | 교차 테이블 |
| 테이블 수 | 동일 | 동일 | +1 (교차) |
| 복잡도 | 낮음 | 낮음 | 높음 |
Ⅳ. 실무 적용 및 기술사 판단
기술사 답안 작성
- ERD에서 관계 유형(1:1/1:N/M:N) 식별.
- 매핑 규칙 번호를 명시하며 변환 과정 서술.
- 결과 릴레이션 스키마에 PK·FK·NULL 여부 명시.
Ⅴ. 기대효과 및 결론
매핑 규칙은 DB 설계의 "번역 문법"이며, 이를 체계적으로 적용하면 ERD의 비즈니스 의미를 손실 없이 릴레이션으로 변환할 수 있다. CASE 도구(ERwin, DA#)가 이 규칙을 자동으로 적용하여 스키마를 생성한다.
📌 관련 개념 맵
| 개념 | 연결 포인트 |
| ERD | 매핑 규칙의 입력 |
| 릴레이션 스키마 | 매핑 규칙의 출력 |
| 교차 테이블 | M:N 관계 매핑의 핵심 산출물 |
| 정규화 | 매핑 후 적용하는 품질 검증 단계 |
| 약한 엔터티 | 소유자 FK + 부분키 복합 PK 매핑 |
📈 관련 키워드 및 발전 흐름도
[ER 모델 (Chen, 1976) — 개념적 데이터 모델]
│
▼
[매핑 규칙 체계화 (1980s) — ERD→릴레이션 7대 규칙]
│
▼
[CASE 도구 (ERwin, 1990s) — 자동 매핑 구현]
│
▼
[Schema-as-Code (2020s) — 코드 기반 스키마 생성]
│
▼
[현재: AI 기반 ERD→스키마 자동 변환]
👶 어린이를 위한 3줄 비유 설명
- ERD는 "학생이 과목을 듣는다"라는 관계를 그림으로 표현한 거예요.
- 매핑 규칙은 이 그림을 **컴퓨터가 이해하는 표(테이블)**로 바꾸는 번역 문법이에요.
- "학생↔과목" 같은 복잡한 관계는 **수강 기록부(교차 테이블)**를 만들어서 연결한답니다!