작성
·
107
·
수정됨
0
현재 트랜잭션관하여 강의를 듣고있는 중입니다. jdbc 트랜잭션 코드랑 jpa 트랜잭션 코드랑 다르다고 하셨는데 이 부분에서 관계정리가 안되거 같아 질문드립니다.
위의 사진처럼 이해하면 되나요??
jpa에서 자체적으로 데이터소스를 관리하는지
jdbc 트랜잭션 코드라고 설명을 해주셨는데 여기서 jdbc가 의미하는게 데이터소스 코드를 의미하는지
위의 두개의 질문도 궁금합니다.
답변 1
0
안녕하세요, 인프런 AI 인턴입니다.
찬영님의 질문에 답변드리겠습니다.
JPA를 이용할 때에는 데이터 소스를 직접 관리하지 않습니다. JPA는 데이터베이스와의 연결을 위해 JDBC API를 사용하지만, JPA 구현체(예: Hibernate)가 데이터 소스 관리, 엔티티 상태 관리, 트랜잭션 관리 등을 추상화하여 제공합니다. 따라서 개발자는 JPA의 고수준 API를 사용해 비즈니스 로직에 더 집중할 수 있습니다.
JDBC 트랜잭션 코드는 데이터베이스 연결을 위해 JDBC API를 직접 사용하는 것을 의미합니다. 여기서 ‘데이터소스 코드’라는 표현은 데이터베이스 연결을 위한 설정 및 관리 코드를 의미할 수 있으며, JDBC는 이런 연결 및 SQL 쿼리 실행, 트랜잭션 관리 등을 직접적으로 코딩하여 제어하게 됩니다. JDBC를 사용할 때는 Connection, Statement 등의 객체를 직접 관리하며, beginTransaction, commit, rollback 등 트랜잭션 관련 작업을 직접 제어해야 합니다.
위의 사진과 같은 데이터 접근 계층 구조는 컨트롤러부터 서비스, 레포지터리(인터페이스 레포지 포함), SQL 매퍼, JPA, JDBC, 그리고 마지막으로 DB에 이르기까지의 흐름을 잘 표현하고 있습니다. 이 과정에서 각 기술이 어떤 역할을 하는지 이해하는 것이 중요합니다. JPA는 JDBC 위에 추상화된 레이어를 제공하여 더욱 직관적이고 객체지향적인 데이터 접근 방법을 가능하게 해줍니다. 반면, JDBC는 SQL과 밀접한 저수준의 데이터 접근 코드를 작성할 때 사용됩니다.
강의 내용을 통해 JPA와 JDBC가 각각 어떻게 트랜잭션을 관리하는지, 그 차이점을 명확히 이해해보시길 추천드립니다.