인프런 커뮤니티 질문&답변

J LEE님의 프로필 이미지

작성한 질문수

스프링 DB 1편 - 데이터 접근 핵심 원리

DataSource 적용

UPDATE에서 궁금한게 생겼습니다!

작성

·

292

0

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

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

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

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

Member member = new Member("member_1",10000);
repository.save(member);

//findById by RepositoryV1
Member memberById = repository.findById(member.getMemberId());
assertThat(memberById).isNotNull();

//update 10000 -> 20000
repository.update(member.getMemberId(),20000);
assertThat(member.getMoney()).isEqualTo(20000);

//delete
repository.delete(member.getMemberId());
assertThatThrownBy(() -> repository.findById(member.getMemberId()))
.isInstanceOf(NoSuchElementException.class);

update하는 테스트 코드를 findById를 통해 가져온 updateMember가 아닌 원래 있던 member.getMoney로 하니까 테스트가 실패하더라구요.

findById를 통해서 가져와야지만 테스트에 성공하던데 원인을 모르겠어서 질문 남깁니다!

답변 2

0

안녕하세요. J LEE님, 공식 서포터즈 David입니다.

기존 member는 값이 업데이트 되지 않고 여전히 10000에 해당하는 값을 가지고 있기 때문입니다.

update 메서드는 기존 member 객체의 값이 아닌 데이터베이스에 있는 id가 member_1인 레코드의 money 값을 변경하는 것이지 member 객체의 값을 변경하고 있지 않습니다.

따라서, 데이터베이스로부터 업데이트 된 상태를 가지는 member를 생성하는 findById 메서드를 사용해야 합니다.

감사합니다.

0

안녕하세요, 인프런 AI 인턴이에요.

질문 내용을 보면 UPDATE 문에 대해 궁금하신 것 같아요.

위 코드는 member 객체를 생성하고, repository를 통해 데이터를 저장하고 조회하는 예시 코드입니다.

update 메소드를 호출하여 member의 money 값을 20000으로 변경한 후 delete 메소드를 호출하여 해당 member를 삭제하는 코드입니다.

해당 코드에서 사용된 update 메소드와 delete 메소드는 repository 클래스 내에 구현되어 있을 것으로 예상되는데, 코드에서는 별도로 구현 내용이 나와있지 않아 참조할 수 있는 정보는 없어 보입니다.

또한, 코드에 존재하는 assertThat 구문은 테스트 코드로 보이며, 각 단계에서 예상한 값과 실제 값이 일치하는지를 확인하는 용도로 사용됩니다.

따라서, 질문하고자 하는 내용이 무엇인지 자세히 알려주시면 더욱 도움을 드릴 수 있을 것 같아요. 어떤 내용에 대해 궁금한 건가요?

그리고 UPDATE 문에 대한 자세한 내용을 알고 싶으시다면, SQL 문법에 관한 공부가 필요할 것 같아요. 인프런의 SQL 관련 강의를 참고하시면 도움이 될 것입니다. 감사합니다.

J LEE님의 프로필 이미지

작성한 질문수

질문하기