inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 데이터 JPA

벌크성 수정 쿼리

벌크성 수정 쿼리도 select를 한 후에 update?

294

lch9502

작성한 질문수 34

0

안녕하세요,

예시로 team_id가 2인 member를 team_id가 1인 member로 변경하고 싶은 경우가 있다고 가정해보겠습니다.  

@Modifying
@Query("update Member m set m.team.id = 1 where m.team.id = :id")
void updateMemberTeamTo1(@Param("id") Long id);

위 코드처럼 단순히 team_id 로 수정하면 update 쿼리 한 번으로 변경이 가능합니다.

@Modifying
@Query("update Member m set m.team = :tobe where m.team = :asis")
void updateMemberTeamTo1(@Param("asis") Team asis, @Param("tobe") Team tobe);

하지만 team 엔티티를 넘긴다면 team id가 1인 Team과 변경할 team id를 가진 Team을 select 해야하니 쿼리가 총 3번 나갑니다.

 

단건 update 를 할 때 변경감지를 사용하기 위해 먼저 PK로 select 하고 있습니다. 그런데 여러건을 벌크성 수정 쿼리로 변경을 할 때도 select를 해서 영속성 컨텍스트에 올린 후 변경해야 할까요?

 

좋은 강의 항상 감사드립니다.

java spring spring-boot jpa

답변 1

0

y2gcoder

안녕하세요. lch9502님, 공식 서포터즈 y2gcoder입니다.

저희가 학습했듯이 벌크성 쿼리의 특성 상 영속성 컨텍스트를 바로 거치지 않고 직접 DB에 쿼리를 날리게 됩니다.
또한 벌크성 쿼리는 대량으로 수정해야 하는 쿼리를 날릴 때, 변경감지로는 성능이 나오지 않아서 보통 사용하게 됩니다.

그런 부분을 종합해보면 현재 벌크성 쿼리를 날리기 위해 select를 2개 더 날리는 것은 벌크성 쿼리를 사용하려는 이유와 대치된다고 볼 수 있을 것 같습니다!

1번째 처럼 pk를 이용해서 날려주셔도 괜찮습니다! 다만 영한님께서 벌크성 쿼리를 설명할 때 말씀해주신 주의사항만 잘 기억해주시면 좋을 것 같습니다!

 

 

감사합니다.

existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?

0

69

1

existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?

0

107

3

MemberRepository 구현체

0

57

1

pdf 표현 질문드립니다.

0

61

1

로그가 남지 않는 문제.

0

81

1

테스트 라이브러리가 강의는 junit4가 맞나요??

0

70

2

pdf 파일과 차이점이 있는 것같은데 문제 없나요?

0

72

2

@PrePersist, @PreUpdate 호출 시점 질문드립니다.

0

91

2

Sort 인터페이스는 잘 사용 안하나요?

0

52

1

스캔대상 질문드립니다.

0

46

1

하이버네이트6에서의 최적화에 이은 질문

0

85

1

save() vs saveAndFlush DB 통신 횟수

0

53

1

순수 JPA 리포지토리 코드 수정부분

0

86

2

bulk연산 후 flush하는 이유를 모르겠어요

0

152

3

bulk insert 질문입니다.

0

178

2

교만했던 것 같아요.

0

147

1

RESTful 강의는 안하시는 건지 궁금합니다.

0

146

2

동적 테이블에 대한 질문

0

85

1

영속성 전이와 연관관계

0

130

2

강의 10:25 질문

0

74

1

단건 update 질문

0

95

2

엔티티 와 도메인의 경계

0

127

1

UsernameOnlyDto 타입 type mismatch 오류

0

119

1

Projection 개념과 데이터 전달과정에 대해 질문 있습니다.

0

136

1