inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 데이터 JPA

스프링 데이터 JPA 6. Update 쿼리

Select 없이 Update만 하고 싶은 경우 베스트 프랙티스가 있을까요?

370

제이킨

작성한 질문수 2

0

안녕하세요 백기선님.

운영중인 프로젝트에 JPA를 적용하다가 Select 없이 Update만 할 경우를 자주 마주합니다.

멤버의 Id와 변경할 포인트를 전달 받아 포인트를 업데이트 하려하면

아래와 같은 순서로 진행해야합니다.

Member member = memberRepo.findById(id)

member.setPoint(member.getPoint + point);

memberRepo.save(member)

이때 member를 select 하는 구문 없이 이번강의에서 알려주신

@modifying(clear...,flush...)와 @query를 이용하면 좋겠다는 생각이 들었거든요.

만약 pointUpdate(memberId, pointAmount)라는 서비스를 제공할 때,

clear와 flush를 보장한다면 서비스를 사용하는 사람도 안심하고 쓸 수 있을것 같구요.

무엇보다 매력적인건 select 한번을 줄일 수 있는 점 같습니다.

테스트 코드에서는 테스트 객체 생성을 위한 create 구문이 있어서

백기선님께서 말씀주신 방향으로 가는게 최적케이스 같습니다.

하지만 기존에 영속화된 엔티티 대상으로 update만 날리기 위해서는

어떤 방법이 더 효율적이라고 생각하시는 지, 주로 사용하시는 패턴이 있으신지 궁금합니다.

java spring JPA

답변 1

0

백기선

셀렉트 쿼리 해보지 않고 바로 업데이트 쿼리만 할 수 있는 방법도 있긴 있어요. 가장 쉬운 예로는 네이티브 쿼리를 만들어 보낸다던지.. 그런데 정말 그래도 안전하겠어요? id값이 제대로 넘어온건지 검증은 안해도 되는건가요?

해당 엔티티에 대한 쿼리가 자주 발생하는건 2차 캐싱을 통해 해결할 수 있습니다. 제 생각엔 그 방법이 더 안정한고 효율적일거 같습니다. "하이버네이트 2차 캐시"라는 키워드로 검색해 보시거나, 김영한님 책을 참고해 보세요.

좋은 질문 감사합니다.

spring boot 2.7.13-SNAPSHOT trace 소문자 로그 안나옴

0

533

1

<스프링 데이터 Common: 기본 리포지토리 커스터마이징> 에 대한 질문

0

392

1

comment table에서 저장될떄 왜 id값이 2부터저장이되는건가요?

0

407

1

@EnableJpaRepositories 설정을 스프링부트가 어디에서 자동설정하나요?

0

451

0

PersistenceContext 관련 질문드립니다.

0

335

1

지금(Eager), 나중에(Lazy)의 의미를 모르겠습니다

0

338

1

transaction 구간이 길어질 경우의 처리방법 문의드립니다.

0

905

1

docker postgres

0

293

1

Multiple DataSource 사용 시 transaction 관련 질문 드립니다.

0

2908

1

entity 중 null이 아닌 필드만 update 할 방법이 있을까요?

0

1191

1

Eager 모드일 경우, join을 inner join으로 바꾸는 법이 있을까요?

0

385

1

엔티티를 상속받는 DTO가 일반적인가요?

1

1847

1

커스텀 타입 클래스를 String 타입 처럼 이용해 쿼리하는 방법에 대해 질문하고 싶습니다.

0

339

1

연관관계 매핑 어떤식으로 해야될지 감이 안잡힙니다.

0

566

4

EntityManager 주입시 Annotation관련 질문드립니다.

0

565

1

클래스 기반 프로젝션 사용 관련 질문

0

560

1

save 메서드 질문드립니다.

0

258

1

복잡한 통계쿼리도 JPA로 가능한가요?

2

5593

1

find 와 get의 차이가 무엇인가요?

0

890

1

실무에서 JPA 할 때 FK로 개발할때 연관관계를 꼭 맺어주어야 하나요?

0

999

1

\dt Did not find any relations.

0

481

1

소스코드는 어디서 볼 수 있을까요?

1

287

1

table 생성과 select 문에 대한 질문

0

174

1

스프링 데이터 RepositoryTest 관련 질문

0

2173

2