inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

자바와 스프링 부트로 생애 최초 서버 만들기, 누구나 쉽게 개발부터 배포까지! [서버 개발 올인원 패키지]

25강. Spring Data JPA를 이용해 자동으로 쿼리 날리기

[spring data JPA] save()에 대해 궁금한 점이 있습니다.

3258

황철원

작성한 질문수 4

3

 public void updateUser(UserUpdateRequest request) {
    User user = userRepository.findById(request.getId())
            .orElseThrow(IllegalArgumentException::new);

    user.updateName(request.getName());
    userRepository.save(user);
}

안녕하세요.

강의를 듣다가 save() 메서드에 대해 궁금한 점이 있어서 작성하게 되었습니다.

updateUser() 메서드에서 파라미터 id 값을 통해 해당되는 객체를 불러온 뒤,

updateName() 메서드를 통해 이름을 변경한 다음,

save() 메서드를 통해 저장한다고 이해했습니다.

 

여기서 save() 메서드를 통해 DB에 저장할 때 변경하기 이전에 저장했던 데이터의 id값이 겹치지 않고 실행이 되는건가요?

 

JPA aws spring spring-boot mysql jpa java

답변 1

1

최태현

안녕하세요, 철원님!!! 아주 좋은 질문 감사드립니다!! 🙏

결론부터 말씀드리면 save() 메소드가 호출될 때 save() 메소드는 2가지 일을 합니다.

  • 이 객체가 DB에서 가져오지 않은 새로운 객체인가

    • 이 경우 insert SQL이 나오며 새로운 데이터가 저장되게 됩니다!

  • 이 객체가 DB에서 가져온적 있는 객체인가

    • 이 경우 update set 필드=변경되는값, ... where id = ? 라는 update SQL이 나가며 기존의 데이터가 저장되게 됩니다!!

 

따라서 질문 주신 경우는 userRepository.findById() 를 통해 JPA Entity인 유저를 가져왔으므로 insert 자체가 나가지 않고 update 문이 나가게 됩니다!

애당초 id를 겹치게 저장하지 않고, '업데이트를 한다'라고 이해해주시면 될 것 같습니다!

 

언제나 또 궁금하신 부분 있으시면 편하게 질문 주세요~

감사합니다, 행복한 주말 되세요!!! 😊

패키지 구분에 대해 궁금한게 있습니다

0

27

2

리액트 관련 질문이 있습니다.

0

65

2

스프링부트 버전

0

78

2

7강 강의를 들으려고 했는데 오류가 나서 서버가 안 켜지는거 같아요.

0

59

2

33강. UserLoanHistory의 관계성에 대한 질문

1

56

2

Java JDK 버전 문의의 건

0

136

2

ec2 에서 Linux버전이 달라져서 설치가 안되는것 같은데 자료 최신화좀 해주세요.

0

90

3

h2 console 접속했을 테이블 질문

1

67

1

ec2 서버에서 스프링 실행도 되고 인바운드 설정까지 했는데 index.html 안됨

0

81

2

15강. updateUser() 질문

0

57

2

깃허브 질

0

86

2

여기까지 다 끝냈다고 하셨는데

0

80

2

왜안될까요

0

72

2

MySQL 창이안ㄴ뜹니다

0

59

2

포스트맨

0

53

1

spring 개념적인 질문

0

72

2

인텔리제이 샘플코드 실행 안됨 오류

0

144

2

aws 배포할때 .env 파일에 저장한 환경변수에 관하여 여쭤볼게 있습니다

0

88

1

마이그레이션 오류입니다.

0

176

3

Whitelabel Error Page 오류가 났습니다.

0

170

2

안녕하십니까! 오류가 났습니다.. 도와주세요 ㅜㅜ

1

94

3

궁금한게 있습니다.

0

61

2

DTO 관련

0

71

2

궁금한게 있습니다!

0

70

2