inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

회원 수정 API

Controller에서 select 쿼리가 왜 안나갈까요?

해결된 질문

572

이상훈

작성한 질문수 2

1

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

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

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

[질문 내용]
여기에 질문 내용을 남겨주세요.

 

회원 수정 API를 구현중 select 쿼리가 왜 안나가는지 궁금해서 질문드립니다.

localhost:8080/api/v2/members/1 을 호출했을때 쿼리가 언제 나오는지 분석해 봤습니다.

  1. update 메서드 실행 -> select 쿼리가 나감

  2. update 메서드 종료직전 -> update 쿼리 나감

  3. updateMemberV2 돌아와서 memberService.findOne()할때는 왜 select가 나가지 않을까요?

 

1========

2023-06-22T12:24:25.330+09:00 DEBUG 55687 --- [nio-8080-exec-9] org.hibernate.SQL :

select

m1_0.member_id,

m1_0.city,

m1_0.street,

m1_0.zipcode,

m1_0.username

from

member m1_0

where

m1_0.member_id=?

2023-06-22T12:24:25.331+09:00 INFO 55687 --- [nio-8080-exec-9] p6spy : #1687404265331 | took 0ms | statement | connection 6| url jdbc:h2:tcp://localhost/~/jpashop2

select m1_0.member_id,m1_0.city,m1_0.street,m1_0.zipcode,m1_0.username from member m1_0 where m1_0.member_id=?

select m1_0.member_id,m1_0.city,m1_0.street,m1_0.zipcode,m1_0.username from member m1_0 where m1_0.member_id=1;

2========

2023-06-22T12:24:25.355+09:00 DEBUG 55687 --- [nio-8080-exec-9] org.hibernate.SQL :

update

member

set

city=?,

street=?,

zipcode=?,

username=?

where

member_id=?

2023-06-22T12:24:25.356+09:00 INFO 55687 --- [nio-8080-exec-9] p6spy : #1687404265356 | took 0ms | statement | connection 6| url jdbc:h2:tcp://localhost/~/jpashop2

update member set city=?,street=?,zipcode=?,username=? where member_id=?

update member set city=NULL,street=NULL,zipcode=NULL,username='dd-hello' where member_id=1;

2023-06-22T12:24:25.358+09:00 INFO 55687 --- [nio-8080-exec-9] p6spy : #1687404265358 | took 0ms | commit | connection 6| url jdbc:h2:tcp://localhost/~/jpashop2

;

3========

2023-06-22T12:24:25.363+09:00 INFO 55687 --- [nio-8080-exec-9] p6spy : #1687404265363 | took 0ms | commit | connection 6| url jdbc:h2:tcp://localhost/~/jpashop2

;

4========

 

java spring spring-boot jpa

답변 1

1

나무늘보

안녕하세요. 이상훈님, 공식 서포터즈 코즈위버 입니다.

OSIV 기본 설정이 ON이라 말씀하신 것 같은 상황이 발생하는것으로 보여요. OSIV 설정을 OFF로 변경한 후 다시 테스트를 해보시겠어요?

OSIV는 별도로 건드리지 않으면 ON이 기본값인데, 이게 ON으로 되어있다면 컨트롤러까지 영속성컨텍스트 데이터가 살아있을 수 있습니다. 개인적으론 OFF로 설정하는 것을 권합니다.

OSIV를 연다는 건, 요리에 비유하면, 주방에서 재료를 다듬다가 냉장고에서 케첩을 하나 꺼낸 뒤 냉장고 문을 닫지 않고 주방으로 향하는 일입니다. 냉장고에서 또 다른 재료를 꺼낼지 모르니 닫지 말고 열어둔다는건 낭비가 심하겠지요? 냉장고로 갔다면 내가 필요한 재료를 한번에 꺼낸다음 문을 잘 닫고 돌아오는게 좋겠지요 :)

감사합니다.

0

이상훈

OSIV OFF 설정해주니까 select쿼리 잘떠요 감사합니다

앞으로 냉장고문 잘 닫을게요 ㅎㅎㅎ

강의 관련 외 질문입니다.

0

67

2

SpringBoot4 + Hibernate7 모듈 등록 방법 공유

0

91

1

BeanCreationException

0

90

3

Update 후 UpdateMemberResponse 매핑할 때

0

49

1

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

0

100

2

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

0

70

1

Query Dsl Q파일 질문입니다.

0

83

1

루트 쿼리라는것은

0

59

1

메서드를 분리하는 기준

0

63

1

findAllWithMemberDelivery 메서드 질문드립니다.

0

110

3

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

0

86

2

fetch join과 영속화와 OSIV의 관계

0

86

2

Distinct 사용 전 결과에 대한 의문

0

114

2

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

0

58

1

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

0

78

2

dto 필드 속 엔티티 여부

0

60

1

뷰템플릿 사용 시

0

76

2

Result 클래스 관련 질문

0

56

1

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

0

86

1

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

0

137

1

OSIV ON 상태일 때

0

96

1

fetch join VS fetch join 페이징 궁금증

0

182

2

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

0

105

1

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

0

165

2