inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 데이터 JPA

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

update 쿼리가 발생하는 이유

해결된 질문

205

jaden

작성한 질문수 44

0

    private Post savePost() {
        Post post = new Post();
        post.setTitle("Spring");
        Post saved = postRepository.save(post);
        return saved;
    }
    @Test
    void updateTitle(){
        Post spring = savePost();
        spring.setTitle("hibernate");

        List<Post> all = postRepository.findAll();
        assertThat(all.get(0).getTitle()).isEqualTo("hibernate");
    }

위 코드에서 insert 후에 update 가 일어나는 이유가 헷갈리네요. 한 트랜잭션 안이니  Post spring 은 managed 상태일테고. 그럼 title을 hibernate로 변경한 상태로 insert 쿼리를 수행해 DB와 싱크를 맞추고 select 쿼리를 날려도 되지않나요? 그런데 insert 하고 update  를 통해 title을 변경하는 이유가 궁금합니다. 

좋은 강의 정말 감사합니다 :) 

java spring JPA

답변 1

1

백기선

좋은 질문입니다. 그 부분은 저도 아쉽게 생각하는 동작 방식인데 하이버네이트가 내부적으로 action 단위(insert, update, delete 등)로 캐싱하고 있기 때문에 그런거라서 어쩔 수가 없네요. 

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

0

532

1

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

0

392

1

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

0

406

1

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

0

450

0

PersistenceContext 관련 질문드립니다.

0

334

1

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

0

338

1

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

0

905

1

docker postgres

0

291

1

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

0

2907

1

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

0

1190

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

5592

1

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

0

890

1

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

0

998

1

\dt Did not find any relations.

0

480

1

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

1

286

1

table 생성과 select 문에 대한 질문

0

172

1

스프링 데이터 RepositoryTest 관련 질문

0

2170

2