해결된 질문
작성
·
28
0
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)
[질문 내용]
앱 프로젝트를 하다 궁금한 점이 생겨 질문드립니다. 지금 같은 경우에 상품을 post 방식으로 그때그때 필요한 것을 추가하는 식 같은데 만약에 처음부터 어떤 항목들인지 지정되어있는 경우에는 어떻게 처리하면 될까요(초기 데이터 설정)? 찾아보니 data.sql
SQL 초기화할 때 실행되는 파일이다. 여기에 SQL문을 작성해주면 된다.
main/resources/db/data.sql에 생성하면 별도 설정없이도 자동으로 해당 파일을 실행해준다.
insert into INTEREST (type)
values ('하이킹'),('서핑'),('다이빙'),('스노클링'),('사파리'),('스키'),('자전거'),
('액티비티'),('음식 체험'),('음악 감상'),('공연 감상'),('전시회'),('예술 관람'),
('사진 촬영'),('지역 축제'),('계획형'),('즉흥형');
이런식으로 한다고 되어있는데 맞는지 궁금합니다..
이 화면을 구현하고 싶은데 @Entity @Getter @Builder @AllArgsConstructor @NoArgsConstructor(access = AccessLevel.PROTECTED) public class Interest { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String type; } 이렇게 구현하면 될까요..?
답변 1
0
안녕하세요. 염경호님, 공식 서포터즈 y2gcoder입니다.
먼저 프로젝트의 요구사항은 다양하고, 제 경험은 그 중 일부에 불과하여 참고만 해주시면 감사하겠습니다 😅
보여주신 데이터들은 봤을 때 주로 상품이 아닌 상품의 태그나 카테고리에 들어가기 좋은 데이터들로 보입니다.
해당 데이터들은 생각하신 바와 같이 처음부터 몇 개의 데이터가 있을 확률이 높습니다!
또한 관리자 페이지(백오피스라고도 합니다)에서 추가할 수도 있고, 그렇지 않을 수도 있습니다.
관리자가 따로 추가하는 기능이 필요 없다면, 상수나 자바의 Enum 클래스를 사용하는 것도 방법입니다.
반면에 관리자가 따로 추가할 수 있어야 한다면 보여주신 것처럼 DB에 저장하는 방식으로 진행해주시는 것도 좋습니다 🙂
DB에 저장할 때는 시드 데이터(말씀하신 것처럼 미리 넣어놓는 데이터를 지칭합니다!) 를 넣는 방법에는 여러가지가 있습니다. 만드신 시드 데이터 삽입용 SQL문을 애플리케이션 구동 시 수동으로 실행하셔도 되고 찾아보신 data.sql을 사용하셔도 되고, Flyway와 같은 마이그레이션 툴을 사용하셔도 좋습니다!
감사합니다.
서비스가 고도화됨에 따라 서비스에 대한 백오피스를 만들면, 해당 백오피스에서 interest를 조작할 수 있는 기능을 줘야하는 요구사항이 발생할 수도 있습니다. 이 때는 초기 데이터 이외의 조작을 할 수 있는 기능을 만들어줘야 하고, 초기 데이터 이외의 데이터를 저장하거나 수정할 수 있는 기능을 제공해야 합니다. 이런 케이스를 말씀드린 것입니다.
백오피스 운영에 대한 고려가 없고, 개발자가 직접 데이터를 밀어넣을 것이며, 해당 데이터가 바뀌거나 추가될 가능성이 없다면 DB로 만들어도 되고, 애플리케이션 단에서 Enum으로 관리하셔도 괜찮습니다 🙂
네 감사합니다! 근데 혹시 관리지가 추가한다는 말씀의 의미가 제가 직접 데이터를 주입한다는 의미인가요? 앱 구동 시 저는 그냥 쿼리를 날려 초기 데이터를 설정하려했는데 이것이 관리자 방식인가요..? 현재 대학 프로젝트에서 저 혼자 백엔드 구축하는 상황이고 실제 aws서버로 띄우는거 까지 목표하고 있습니다..!! 그리고 추가로 상수나 enum클래스 사용 방법은 어떤식으러 하는 것인가요??