작성
·
228
0
현재 MyBatis를 사용한 프로젝트를 JPA로 변경하려 합니다.
Mybatis는 생성자로 Db로직 클래스에서 생성되고 메소드별로 sqlSession을 불러들여서 쿼리를 실행하고 닫는 과정인데
1. JPA도 마찬가지로 EntityManager와 EntityTransaction을 메소드마다 열고 닫았다 해야되나요? (아래 예제 코드 첨부드립니다.)
2. 열고 닫으면 영속성 컨텍스트도 같이 내려가는 건가요?
public class DbLogic{
EntityManagerFactory emf;
EntityManager em;
EntityTransaction tx;
static Logger logger = LoggerFactory.getLogger(DbLogic.class.getName());
public JpaDAO() {
this.emf = Persistence.createEntityManagerFactory("JPA");
}
public void find() {
try {
em = emf.createEntityManager();
tx = em.getTransaction();
tx.begin();
em.find(Device.class, 1);
} catch (Exception e) {
tx.rollback();
e.printStackTrace();
}finally {
em.close();
}
}
}
답변 1
1
안녕하세요. 지우님
지금은 JPA를 순수하게 학습하기 때문에 이런 코드를 직접 다 다룹니다.
그런데 실무에서는 스프링과 JPA를 함께 사용합니다.
그러면 다음 코드가 이렇게 바뀝니다.
class ... {
@Autowired EntityManager em;
@Transactional
public findDevice(Long id) {
em.find(Device.class, id);
}
}
추가로 트랜잭션이 종료되면 영속성 컨텍스트도 함께 종료하도록 맞추어야 하는데, 이런 부분까지 스프링이 자동으로 처리해줍니다.
관련해서 활용1편을 공부해보시면 이해가 되실거에요.
감사합니다.