저장할 데이터 파악하기 / 그룹핑해서 분류하기
1. 요구 사항
현업에서 아래와 같이 글로만 된 요구 사항만 가지고 DB 설계를 하는 일은 잘 없다. UI(화면) 디자인이 나왔을 때 UI 디자인을 보면서 DB 설계에 들어가는 편이다. 하지만 지금은 연습을 하기 위함이니까 아래 요구사항만 가지고 설계를 해보자.
1)회원가입 기능
-회원가입을 할 때 이메일, 비밀번호, 이름의 정보를 받는다.
2)로그인 기능
-로그인할 때 이메일, 비밀번호를 활용해서 로그인한다.
3)게시글 작성 기능
-로그인한 사용자만 게시글을 작성할 수 있다.
-게시글에는 제목과 내용을 작성할 수 있다.
4)게시글 조회 기능
-작성자, 게시글 제목, 게시글 내용, 게시글 작성 시간을 조회할 수 있어야 한다.
2. 저장할 데이터 파악
요구사항을 보면서 데이터베이스에 어떤 데이터를 저장해두어야 할 지 파악하는 게 가장 먼저다. 어떤 데이터를 저장해두어야 하는 지 파악해야, 어떤 방식으로 데이터를 분류해서 저장할 지 결정할 수 있다.
1)회원가입 기능
-회원가입을 할 때 이메일, 비밀번호, 이름의 정보를 받는다.
2)로그인 기능
-로그인할 때 이메일, 비밀번호를 활용해서 로그인한다.
3)게시글 작성 기능
-로그인한 사용자만 게시글을 작성할 수 있다.
-게시글에는 제목과 내용을 작성할 수 있다.
4)게시글 조회 기능
-작성자, 게시글 제목, 게시글 내용, 게시글 작성 시간을 조회할 수 있어야 한다.
3. 그룹핑해서 분류하기
저장해야 하는 데이터를 묶어서 그룹핑 할 수 있는 상위 개념을 찾아야 한다. 이렇게 그룹핑 된 하나의 그룹을 보고 데이터베이스에서는 엔티티(Entity)라고 얘기한다.엔티티(Entity)가데이터베이스의 테이블(Table)이라고 생각해도 된다.
이메일, 비밀번호, 이름 → 사용자
작성자, 게시글 제목, 게시글 내용, 게시글 작성 시간 → 게시글
빨리 토이프로젝트 UI 보고, 데이터 파악하고 그룹핑해보고 싶다!!!
'인프런 - 비전공자도 이해할 수 있는 DB 설계 입문/실전' 강의를 수강하며 내용 정리를 위해 작성한 포스팅입니다.
인용은 JSCODE님 수업자료에서 퍼온 것입니다.