inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

[개정판 2023-11-27] Spring Boot 3.x 를 이용한 RESTful Web Services 개발

JPA를 이용한 사용자 추가와 삭제 - HTTP POST/DELETE method

1번 회원 삭제 후, 1번 개별조회는 안되고, DB에는 데이터가 남아있는 현상 질문입니다

해결된 질문

813

Truestar

작성한 질문수 68

0

관심 가져주셔서 감사합니다.
약간의 리팩토링과, 응용을 거쳐 DB처리에 문제가 없도록 했었습니다.

UserJpaController.java

@RestController
@RequestMapping("/jpa")
public class UserJpaController {
...

@DeleteMapping("/users/{id}")
public MappingJacksonValue deleteUser(@PathVariable Integer id) {
final User deleteUser = getUserById(id);

userRepository.delete(deleteUser); //> here

return getMappingJacksonValueByModel(
deleteUser,
"UserInfo",
getFilterByModelFields("name", "joinDate")
);
}

...
}

설정이 추가된 환경 요소입니다

문제

  1. 1번 회원 조회 - 정상 출력


  2. 회원 1번을 삭제합니다
    : 그러나, Delete 쿼리가 Log 에 없습니다


  3. 1번 회원 재 조회시 없다고 출력됩니다

  4. 전체 회원조회를 하면 1번회원이 살아있습니다

    : 이것은 즉, 전체조회 쿼리는 Log에 남고,
    Delete 쿼리는 전송되지 않는것 같습니다.

    -Delete user 요청 후 DB 테이블

  5. DELETE /jpa/users 요청 후 서버  log 입니다
    : save() .deleteById()  &  delete() 모두 안됩니다


질문

  1. JPA EntityManager 에서 트렌젝션 처리가( em.flush() ) 안된것으로 추측이 됩니다만, 이부분은 JpaRepository 구현체 에서 자동처리가 되어야 하는것이 아닌가요?

    - 아래와 같이 Controller 에서 실행해 보았으나, 역시나 쿼리전송이 안되는것 같습니다
    userRepository.delete(deleteUser);
    userRepository.flush();
  2. @Transactional 을 Controller 에 붙여 주는걸로도 해결이 안되는데 혹시 추가해결방법이 있을까요?


  3. 서버 메세지 중
    Did not store anonymous SecurityContext
    이것이 왜 뜨는것일까요... 인증문제 같습니다.
    (서버에 예제와 같이 Security 초기 설정을 했습니다)
    : 웹브라우저 상에서 /h2-console 접근은
    모두 가능합니다.
    - jdbc:h2:mem:testdb
    - jdbc:h2:tcp://localhost:9092/mem:testdb

제가 놓치고 있는것에 대해 조언을 구합니다
감사합니다.

rest-api spring-boot

답변 2

1

Dowon Lee

안녕하세요, 이도원입니다. 

답변을 찾으셨네요. 동감이빈다. 

"졸지맙시다.. 졸릴떈 자고 합시다 ㅠ"  ^^;

감사합니다.

0

Truestar

리쿼스트 테스트 툴을 여러개를 두는 이유를 알게된것같습니다..실수를 만회할 시간을 벌어주는것을요

인텔리제이 .http가 편해서 주구장창 쓰다가 이런일도 겪게되네요.. 포스트맨은 리커버용으로 두겠습니다ㅎㅎ

감사합니다

0

Truestar

이번에도 역시나 자문자답의 힘으로 해결되었습니다.
응용하다 실수한 것이라, 만회하려고 많은 시간을 쏟아부으며 결국 해결했습니다.

HTTP Request URI : `/jpa/users` 를 `/users` 로 호출을 계속 하고 있었습니다

정말, 매번 같은 실수를 하게되는것 같습니다.

`참조경로 Miss...` `오타`

쳇바퀴에 올라타지 않으려 노력하지만, 
`졸음`이란건, 이런 노력을 무산시키는 무시무시한 녀석이란걸 다시 새기고 갑니다.

졸지맙시다.. 졸릴떈 자고 합시다 ㅠ

화이팅입니다

JPA

0

70

1

jpa dependency를 추가하고 SecurityConfig클래스에서 오류가 납니다.

0

84

1

웹 브라우저 400 bad request

0

83

1

@Size는 되는데 @Past는 안 됩니다.

0

76

1

pdf 자료는 없나요?

0

90

2

locale 정보가 null 이면 무조건 messages_ko.properties이 호출 되는 문제

0

98

2

Swagger 강의, Unable to infer base url 이거 뜨시는 분들 도움되시라고

0

132

1

강의에서나온 화면 피피티

0

169

1

HelloWorldBean 관련 에러

0

194

2

Swagger API 3.x 오류..

0

229

1

java: variable message not initialized in the default constructor 에러는 어찌하면 좋을까요?

1

288

1

현재 GIT에 올리신 소스를 실행해봤습니다.

0

203

2

고양이 소리가 귀엽네요 !!

0

148

2

git에서 소스받고 실습중인데

0

127

1

post가 안되요

0

113

1

한국어 같은 경우 언어코드인 messages_ko.properties 로 생성하는게 더 좋지 않나요?

0

176

2

리턴타입으로서 EntityModel<User> 와 ResponseEntity질문

0

112

1

예외처리쪽 관련 질문있습니다.

0

165

2

엔티티가 바로 응답으로 나가도 되나요??

0

239

2

안녕하세여 Cannot invoke "co.kr.joneconsulting.resfulservice.repository.PostRepository.save(Object)" because "this.postRepository" is null

0

150

2

사용자 등록하고 나서 H2 에서 보면 신규 사용자의 password, ssn 이 null 로 되어 있습니다.

0

146

2

ApplictionContext 질문

0

199

2

롬북이 안먹히는것같아요

0

161

1

인텔리제이에서스프링부트 파일 실행하면

0

244

1