해결된 질문
작성
·
359
·
수정됨
0
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)
[질문 내용]
보통 jpa에서 제공하는 save는 Customer를 저장하고 싶은 경우(모든 컬럼에 값이 설정돼있지 않음)
Customer customer = new Customer();
customer.setCustomerName("aa");
customerRepository.save(customer);
setter로 설정하기엔 컬럼이 너무 많은데
이게 맞는건지
아니면 컨트롤러에서 파라미터를 OrderVO로 받아서 Entity로 변환한 다음 저장하는게 맞는지 잘 모르겠습니다.
답변 1
1
안녕하세요. 이혜정님, 공식 서포터즈 David입니다.
map을 Customer로 바꿔주는 로직 밖에 없다면 굳이 map을 쓸 필요가 없을 것 같습니다. 그냥 DTO를 만드는 게 더 유효성 검사를 적용하기 쉽습니다. 반드시 Map을 사용해야 한다면 Map을 순회하면서 요소들을 검사하는 별도의 유효성 검사기를 구현하셔야 할 것 같습니다. 이와 관련된 내용은 다음 링크를 참고해 주세요. https://stackoverflow.com/a/57127912
수정자 이외에도 객체의 생성자나 빌더, 매퍼를 활용하셔도 됩니다. 또한 말씀하신 대로 DTO에서 Entity로 변환하는 메서드를 만들어도 좋습니다.
감사합니다.