inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화

Entity 저장에 관해 문의드립니다.

375

jhkweon74

작성한 질문수 3

1

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
여기에 질문 내용을 남겨주세요.
 
안녕하세요. 영항님! 좋은 강의 잘 듣고 있습니다.
강의를 듣고 토이 프로젝트를 진행하는 와중에 궁금한 점이 생겨 질문글을 올리게 되었습니다.
저는 Board라는 Entity를 다음과 같이 선언하였습니다.
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "board_id")
private Long id;
private String title;
private String topic;
private String content;
@Enumerated(EnumType.STRING)
private StudyState studyState;
@Enumerated(EnumType.STRING)
private RecruitState recruitState;
private Long headCount;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "member_id")
private Member member;

그리고 저는 프론트에서부터 전달받은 Dto로 실제 Board Entity를 저장하려고 했습니다.

그래서 저는 Dto로 부터 Entity를 만들 수 있는 메소드 toEntity를 다음과 같이 구성하였습니다.

@Data
@NoArgsConstructor
@AllArgsConstructor
public class BoardCreateRequestDto {
private Long memberId;
private String title;
private String topic;
private String content;
private Long headCount;
private StudyState studyState;
private RecruitState recruitState;

public Board toEntity() {
return Board.builder()
.title(this.title)
.topic(this.topic)
.content(this.content)
.studyState(this.studyState)
.recruitState(this.recruitState)
.headCount(this.headCount)
.member(new Member(this.memberId))
.build();
}
}
Board board = boardRepository.save(requestDto.toEntity());

실제로 저장을 할 시에 Board Entity에는 Member를 넣어 저장하나, 실제 DB에서는 Board 객체에서의 Id만을 외래키로 저장하기에 다음과 같이 저장해도 무방하다는 것을 알게 되었습니다.

저는 이 방법이 MemberId를 통해 Member 객체를 찾지 않고 저장할 수 있기에 쿼리 1번을 덜 날릴 수 있어 비용적인 측면에서 조금의 이득이 생긴다고 생각하여 다음과 같이 구성해보았습니다.

이러한 방법이 문제가 있는지 궁금합니다.

spring-boot JPA spring java

답변 1

0

김영한

안녕하세요. jhkweon74님

이렇게 작성하셔도 됩니다.

다만 지연 로딩, Fetch join 같은 기능을 사용할 수 없습니다.

추가로 프록시를 사용하면 연관관계를 유지한 상태로 추가 쿼리를 호출하지 않는 방법도 있습니다.

https://www.inflearn.com/questions/204850

감사합니다.

0

jhkweon74

주말에도 정성스런 답변 감사드립니다!

영한님께서 이렇게 작성할 경우 지연 로딩, Fetch Join 같은 기능을 사용할 수 없다는 부분에 대해 이해가 잘 가지 않습니다.

해당 트랜잭션에서 save가 처리되고 트랜잭션이 종료되면 정상적으로 DB에 FK값이 저장되어 추후에 다시 사용할 때는 DB의 정보를 토대로 지연 로딩 혹은 Fetch Join하여 정상적으로 사용 가능한 것이 아닌가요?

아니면 영한님께서 말씀해주신 부분이 save 처리중인 해당 트랜잭션 내에서 사용이 불가능하다는 것을 의미하는 건가요?

이 부분에 대해서 테스트를 진행해보았을 때, 테스트가 통과하는 모습을 보였는데 혹시 제가 테스트를 잘못 진행했을까요..?

@Query("select b from Board b join fetch b.member")
List<Board> findAllByFetchJoin();
@Test
public void fetchJoin() throws Exception {
//given
Member member = Member.builder()
.email("email")
.nickname("nick")
.build();
Member saveMember = memberRepository.save(member);

for (int i = 0; i < 10; i++) {
Board board = Board.builder()
.title("Test")
.member(new Member(saveMember.getId()))
.build();
boardRepository.save(board);
}

em.flush();
em.clear();

//when
List<Board> boards = boardRepository.findAllByFetchJoin();

//then
for (Board board : boards) {
System.out.println("board = " + board.getMember().getEmail());
}
}

0

김영한

jhkweon74님 제가 DTO 코드를 엔티티로 착각했네요^^;

 

강의 관련 외 질문입니다.

0

85

2

SpringBoot4 + Hibernate7 모듈 등록 방법 공유

1

102

1

BeanCreationException

0

99

3

Update 후 UpdateMemberResponse 매핑할 때

0

59

1

트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?

0

104

2

페이징 + 검색조건 관련해서 질문드립니다.

0

74

1

Query Dsl Q파일 질문입니다.

0

86

1

루트 쿼리라는것은

0

62

1

메서드를 분리하는 기준

0

72

1

findAllWithMemberDelivery 메서드 질문드립니다.

0

116

3

연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략

0

92

2

fetch join과 영속화와 OSIV의 관계

0

92

2

Distinct 사용 전 결과에 대한 의문

0

121

2

레포지토리 계층에서의 트랜잭션에 대한 의문

0

63

1

영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.

0

79

2

dto 필드 속 엔티티 여부

0

64

1

뷰템플릿 사용 시

0

83

2

Result 클래스 관련 질문

0

58

1

@PostConstruct 프록시 관련 질문드립니다

0

88

1

DTO 대신 Form 사용은 안되나요?

0

141

1

OSIV ON 상태일 때

0

100

1

fetch join VS fetch join 페이징 궁금증

0

191

2

양방향 연관관계 알아보는 법?

0

110

1

16강 17강 간단 정리 이게 맞을까요 ?

0

169

2