예제 item-service 에서 JPA 추가하는데 질문 드립니다.
292
작성한 질문수 9
안녕하세요. 강의 예제대로 진행하면서
마지막에 완성된 item-service를 기초로 하여 H2 데이터베이스를 이용한 JPA 구현을 직접 해보려고했습니다.
기존 예제와 다른점은 Store라는 domain 클래스를 직접 만들어보고 Item과 매핑해보았습니다.
Item, Store 클래스에 대해 엔티티 설정을 해주었습니다.
먼저 /resources/META-INF/persistence.xml 을 생성하여 JPA 영속성 관련 설정을 해주었습니다.
그리고 EntityManagerFactory 클래스의 공유 변수를 위해 MyEntityManagerFactory 클래스를 만들었습니다.
컨트롤러, 서비스, 레포지토리 클래스에는 모두 각각
@Controller, @Service, @Repository 어노테이션을 추가하여 빈으로 등록 해주었고 빈으로 정상등록되는지도 확인했습니다.
먼저 문제점은 @Transactional 어노테이션이 정상적으로 적용이 안된다는 것입니다.
Item 객체를 추가하는 코드를 보면
이처럼 EntityManager에서 EntityTransaction을 만든 후
tx.begin()과 tx.commit()을 추가하여 실제 웹에서 테스트 해본결과 정상적으로 Item이 생성되며 DB까지 값이 들어갑니다.
위와 다르게 EntityTransaction 을 사용하지 않고 @Transactional 어노테이션을 이용하기 위해 코드를 변경했습니다.
먼저 서비스인 BasicItemService 클래스에 @Transactional 어노테이션을 추가했습니다.
그런 다음에 기존의 ItemRepository의 create 메소드의 tx 부분을 주석처리 했습니다.
제가 생각한 것은 서비스 클래스에서 @Transactional이 명시되어있기 때문에 레포지토리의 create 메소드 에서 em.persist(data)가 실행 된후 메소드가 종료 될 때 자동으로 commit이 될것이라고 생각했습니다. 하지만
실제로 아이템을 등록해보니 아래와 같은 오류가 발생했습니다.
2021-04-14 23:36:52.404 ERROR 22660 --- [nio-8081-exec-2] o.a.c.c.C.[.[.[/].[dispatcherServlet] : Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is java.lang.IllegalArgumentException: Model has no value for key 'itemId'] with root cause
레포지토리에서 commit이 정상적으로 되지 않아서 AddForm에서 입력받은 데이터로 Item이 생성되지 않았고, 아이템이 생성되지 않았고 AddForm에서 Item 상세정보로 리다이렉트를 할때 itemId 값이 null이라서 오류가 발생했습니다.
사용하는 dependency는 다음과같습니다.
@Transactional 에 대해 여러 정보를 찾아봤는데 해결법을 찾지 못해서 질문드립니다!
답변 1
0
안녕하세요. Jungyu Choi님^^
JPA를 스프링과 함께 사용하면 스프링이 제공하는 설정들을 사용하거나 스프링 부트가 제공하는 설정을 사용해야 합니다.
JPA와 스프링을 함께 사용하는 방법에 대해서는
실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발
강의를 참고해주세요.
감사합니다.
servlet과 container에 대한 질문입니다
0
15
1
api를 어느 컨트롤러에 작성해야하는지는 어떤 기준으로 해야하나요?
0
59
1
jsp 의존성 수정 요청
0
72
2
요즘 웹 서버가 주로 사용되는 이유는 SPA 구조 때문일까요 ?
0
141
1
save() 메서드 문의
0
62
1
절대 경로로 templates/basic 하위 파일 열면 css 적용 안되는 현상
0
98
1
request-body-json
0
83
2
MVC 패턴의 적용 단위
0
92
1
RequestMapping을 이용한 핸들러, 어댑터
0
118
2
save 후 결과화면
0
86
2
jsp를 이용한 view
0
95
1
application.properties에 debug 추가해도 결과가 똑같습니다.
0
170
1
수업 코드 제공 관련 문의
0
95
2
RequestMappingHandlerAdapter의 Controller 호출 과정
0
96
3
파일 오픈 시
0
66
1
스프링 배치 관련
0
75
1
@RequestParam의 defaultValue가 blank 값도 처리하는 지 여부
0
110
1
postman으로 /request-body-json-v1 호출시 500 error
0
93
1
프론트엔드와 백엔드의 mvc, rest api에 대한 질문
0
74
1
모델의 역할과 계층 분리에 대한 이해 차이 + 추가질문
0
110
1
console log 출력 관련 질문입니다.
0
73
1
애플리케이션이 실행 되지 않습니다 ㅠㅠㅠ
0
135
1
html 변경하는 부분 적용 문제
0
98
1
한글 깨짐
0
72
2





