ERD 다이어그램 그리는 방법

ERD를 그릴 때는 좌변과 우변의 관계를 중심으로 생각해보세요.
Apr 22, 2024
ERD 다이어그램 그리는 방법
✍🏼
‘이론 한 점’은 내일배움캠프 강민준 튜터님이 수강생에게 요약해주는 컴퓨터 사이언스 지식 코너입니다. 오늘의 이론은 ERD 다이어그램 그리기 꿀팁과 예시를 알려주셨습니다.
 
 
 
여러분 안녕하세요. ERD를 막상 짜보려니 난감하신 분들을 위해 10분 컷으로 이해시켜 드리러 왔습니다. ERD를 작성하실 때는 주인공(좌변)개체로부터 상대(우변)개체로의 '관계'만 생각하시면 됩니다. 그 관계가 1:1인지 1:다(多)인지, 필수인지 선택인지만 생각해보시면 됩니다!
 
💡
ERD란?
ERD는 Entity Relationship Diagram(엔티티 관계 다이어그램)의 약자입니다.
데이터베이스 설계 과정에서 사용되는 모델링 기법 중 하나로, 데이터베이스에 저장될 데이터 엔티티(entity)들과 엔티티 간의 관계(relationship)를 시각적으로 표현합니다. ERD는 데이터베이스 설계의 초기 단계에서 개념적 모델을 만드는 데 사용되며, 다음과 같은 요소로 구성됩니다.
ERD를 통해 데이터베이스 구조를 시각화할 수 있어 개발자와 설계자 간의 의사소통이 원활해지고, 데이터베이스 구조의 논리적 모순을 조기에 발견할 수 있습니다.
 
 

ERD 작성하는 방법

  • 개체(Entity): 사각형
  • 속성(Attribute): 동그라미
  • 관계(Relation): 마름모
notion image
 
마름모 모양의 관계에는 어떤 ‘행동’에 의해서 관계가 되어 있는지 작성해 주시면 됩니다.
하지만 아래 그림처럼 마름모 모양의 관계를 생략해서 작성하기도 해요.
notion image
 
아래와 같이 개체를 테이블로 작성하셔도 됩니다.
notion image
 
속성에 관계선을 이어주기도 합니다. 외래키가 어디에 설정되어 있는지 확인하기에 좀 더 직관적입니다.
notion image
 
 

ERD 그리기 유용한 툴

  • 엑셀, 파워포인트, 워드, Figma 등 수정하기 편한 도구
  • SQL ALchemy나 Django-estensions 등
 
 

ERD 예시

회원, 게시글, 좋아요, ERD 예시
회원, 게시글, 좋아요, ERD 예시
주인공 개체 입장으로 하나씩 해석해볼까요?
case1. 회원 테이블을 주인공으로 잡았을 때
  • 회원1명당 게시글은 0~N개가 있다. → 눈팅만 하는 회원일 있을 수도 있음 게시글은 회원 1명은 필수! → 게시글 하나를 여러 회원이 작성하진 않음
  • 회원1명당 댓글은 0~N개가 있다. → 눈팅만 하는 회원일 있을 수도 있음 댓글은 회원 1명은 필수! → 댓글 하나를 여러 회원이 작성하진 않음
  • 회원1명당 좋아요는 0~N개가 있다. →좋아하는게 없을 수도 있음 좋아요는 회원 1명은 필수!
 
case 2. 게시글 테이블을 주인공으로 잡았을 때
  • 게시글 N개당 회원 1명은 필수로 있다. → 게시글 하나를 여러 회원이 작성하진 않으니까 단, 회원한테 게시글은 0개일수도 있다. → 눈팅만 하는 회원이 있을 수도 있음
  • 게시글 1개당 좋아요 0~N개가 있다. → 좋아요를 못받는 게시글이 있을 수도 있음 ㅜㅜ 좋아요는 게시글 1개는 필수! → 좋아요가 있다는 의미는 게시글이 있다는 의미
  • 게시글 1개당 사진이 1~N개가 있다. 사진은 게시글 1개는 필수!
  • 게시글 1개당 0~1개의 범주(Kategorie)가 있다.
→ 새로운 품목일 경우 범주 외일 수도 있음, 0개되는게 싫다면 ‘기타’ 라는 범주를 만들어서 필수로 선택하게 만들면 해결 가능! 범주는 게시글 1개는 필수!
  • 게시글 1개당 댓글이 0~N개가 있다. 댓글은 게시글 1개는 필수!
 
case 3. 좋아요 테이블을 주인공으로 잡았을 때
  • 좋아요 N개당 회원 1명은 필수로 있다. 단, 회원한테 좋아요는 0개일수도 있다.
  • 좋아요 N개당 게시글 1개는 필수로 있다. 단, 게시글한테 좋아요는 0개일수도 있다.
 
case 4. 범주 테이블을 주인공으로 잡았을 때
  • 범주 1개당 게시글 1개는 필수로 있다. 단, 게시글은 범주가 0개일 수도 있다.
→ 새로운 품목일 경우 범주 외일 수도 있음, 0개되는게 싫다면 ‘기타’ 라는 범주를 만들어서 필수로 선택하게 만들면 해결 가능!
 
case 5. 사진 테이블을 주인공으로 잡았을 때
  • 사진 N개당 게시글 1개는 필수로 있다. → 사진도 없이 중고품을 올릴 수는 없게 하자!
 
위 예시는 예시일뿐, 여러분들의 시스템에 맞게 설계해주시면 됩니다!
notion image
 
 
 

웹 개발에 AI 역량을 더하고 싶다면? 내일배움캠프 AI 트랙에 합류하세요

내일배움캠프의 AI 트랙에서는 웹 개발 역량에 AI 기술을 접목하여 웹 개발, 머신러닝 등 다양한 분야에 도전할 수 있습니다. 파이썬과 장고로 웹 개발 기술을 배우고, 머신러닝 라이브러리와 ChatGPT API를 활용하여 프로젝트를 진행합니다. 현업 웹 개발자와 머신러닝 개발자의 피드백을 받으며 실제 유저 서비스 런칭까지 경험할 수 있어 차별화된 포트폴리오를 갖출 수 있습니다. 내일배움카드만 있다면 이 모든 과정에 무료로 참여할 수 있습니다. 내일배움캠프 AI 트랙과 함께 채용 시장에서 주목받는 지원자로 거듭나세요.
 
 
 
CREDIT
답변 | 강민준 내일배움캠프 AI 웹 과정 튜터 편집 | 정효재 팀스파르타 에디터
Share article
Subscribe Newsletter
Stay connected for the latest news and insights.
RSSPowered by inblog