JSCODE Logo
프로그래밍 과외블로그후기멘토진
회사명 : JSCODE대표 : 박재성사업자 등록번호 : 244-22-01557통신판매업 : 제 2023-인천미추홀-0381 호
학원 명칭 : 제이에스코드(JSCODE)원격학원학원설립ㆍ운영 등록번호 : 제6063호

서울특별시 구로구 경인로 20가길 11(오류동, 아델리아)

Copyright ⓒ 2025 JSCODE - 최상위 현업 개발자들의 프로그래밍 교육 All rights reserved.

이용약관개인정보처리방침
← 블로그 목록으로 돌아가기

[규칙 3] 헷갈릴 땐 관계(1:1, 1:N, N:M)를 파악해봐라 - 1

JSCODE 박재성
JSCODE 박재성
2025-12-06
author
JSCODE 박재성
category
DB 설계
createdAt
Dec 6, 2025
series
비전공자도 이해할 수 있는 DB 설계 입문/실전
slug
rule-3-understand-relationships-1
type
post
updatedAt
Dec 6, 2025 05:57 AM

✅ 1:1 관계 / 1:N 관계 / N:M 관계 ?

옛날 개발자들이 수많은 DB 설계 케이스를 접하다보니 엔티티 간의 관계에서 패턴을 찾은 것이다. 그게 바로 1:1 관계, 1:N 관계, N:M 관계라는 패턴이다. 이 개념을 알게 되면 DB 설계 할 때 조금 더 수월하게 할 수 있다. 그럼 지금부터 1:1 관계, 1:N 관계, N:M 관계에 대해 알아보자.
 

✅ 엔티티 관계 파악 방법

  1. 엔티티 간에 어울리는 동사 찾기
      • A(주어)가 B를 _____. (A가 주어)
      • B(주어)가 A에 의해 ______. (B가 주어)
      ** 서비스의 관점에서 동사를 떠올려야 한다.
       
  1. 1번 과정에서 찾은 동사를 활용해 적절한 단어(하나의 or 여러 개의) 찾기
      • 하나의 A는 (하나의 or 여러 개의) B를 _______. (A의 관점)
      • 하나의 B는 (하나의 or 여러 개의) A에 의해 _______. (B의 관점)
      ** 문장 처음에 시작하는 하나의라는 말을 반드시 붙여야 헷갈리지 않는다.
      ** 서비스를 어떻게 기획하냐에 따라 달라질 수 있다. 반드시 자신의 서비스에 대입해서 생각해야 한다.
       
  1. 관계 판단하기
      • A, B의 관점 전부 다 하나만 기진다면 → A : B = 1 : 1
      • A의 관점에서는 여러개의 B를 가지고, B의 관점에서는 하나의 A를 가진다면 → A : B = 1 : N
      • A의 관점에서는 하나의 B를 가지고, B의 관점에서는 여러개의 A를 가진다면 → A : B = N : 1
      • A, B의 관점 전부 다 여러개를 가진다면 → A : B = N : M
 
방법만 봤을 때는 어렵게 느껴질 수도 있다. 예시를 바로 보자.
 
 
 
author
category
DB 설계
createdAt
Dec 6, 2025
series
비전공자도 이해할 수 있는 DB 설계 입문/실전
slug
type
series-footer
updatedAt
Dec 6, 2025 05:57 AM
📎
이 글은 비전공자도 이해할 수 있는 DB 설계 입문/실전 강의의 수업 자료 중 일부입니다.