JPA란?
JPA는 자바 진영의 ORM 표준 기술이다. JPA는 애플리케이션과 JDBC 사이에서 동작한다.
ORM(Object-Relational Mapping)은 이름 그대로 객체와 관계형 데이터베이스를 매핑한다는 뜻이다.
ORM 프레임워크는 객체와 테이블을 매핑해서 패러다임의 불일치 문제를 개발자 대신 해결해 준다.
따라서 객체 측면에서는 정교한 객체 모델링을 할 수 있고 관계형 데이터베이스는 데이터베이스에 맞도록 모델링하면 된다. 그리고 둘을 어떻게 매핑해야 하는지 매핑 방법만 ORM 프레임워크에게 알려주면 된다. 덕분에 개발자는 데이터 중심인 관계형 데이터베이스를 사용해도 객체지향 애플리케이션 개발에 집중할 수 있다.
JPA는 자바 ORM 기술에 대한 API 표준 명세다. 쉽게 이야기해서 인터페이스를 모아둔 것이다.
따라서 JPA를 사용하려면 JPA를 구현한 ORM 프레임워크를 선택해야 한다. 이 중에 하이버네이트가 가장 대중적이다.
jpa.persist(member) //저장
JPA에서 데이터를 저장할 때, 위의 코드를 실행하게 되면 위 그림과 같은 구조를 통해 DB에 저장된다.
Member member = jpa.find(memberId) //조회
JPA에서 데이터를 조회할 때, 위의 코드를 실행하게 되면 위 그림과 같은 구조를 통해 DB에 저장된다.
왜 JPA를 사용해야 하는가?
생산성
JPA를 사용하면 다음 코드처럼 자바 컬렉션에 객체를 저장하듯이 JPA에게 저장할 객체를 전달하면 된다.
jpa.persist(member) //저장
Member member = jpa.find(memberId); //조회
INSERT SQL을 작성하고 JDBC API를 사용하는 지루하고 반복적인 일은 JPA가 대신 처리해 준다.
따라서 지루하고 반복적인 코드와 CRUD용 SQL을 개발자가 직접 작성하지 않아도 된다.
더 나아가서는 JPA는 DDL문을 자동으로 생성해 주는 기능도 있다.
이런 기능을 사용하면 데이터베이스 설계 중심의 패러다임을 객체 설계 중심으로 역전시킬 수 있다.
유지보수
SQL을 직접 다루면 엔티티에 필드를 하나만 추가해도 관련된 등록, 수정, 조회 SQL과 결과를 매핑하기 위한 JDBC API 코드를 모두 변경해야 했다.
반면에 JPA를 사용하면 이런 과정을 JPA가 대신 처리해 주므로 필드를 추가하거나 삭제해도 수정해야 할 코드가 줄어든다.
패러다임의 불일치 해결
JPA는 상속, 연관관계, 객체 그래프 탐색, 비교하기와 같은 패러다임의 불일치 문제를 해결해 준다.
성능
JPA는 애플리케이션과 데이터베이스 사이에서 다양한 성능 최적화 기회를 제공한다.
JPA는 애플리케이션과 데이터베이스 사이에서 동작한다. 이렇게 애플리케이션과 데이터베이스 사이의 계층이 하나 더 있으면 최적화 관점에서 시도해 볼 수 있는 것들이 많다.
String memberId = "helloId";
Member member1 = jpa.find(memberId);
Member member2 = jpa.find(memberId);
JDBC API를 사용해서 해당 코드를 직접 작성했다면 회원을 조회할 때마다 SELECT SQL을 사용해서 데이터베이스와 두 번 통신했을 것이다. JPA를 사용하면 회원을 조회하는 SELECT SQL을 한 번만 데이터베이스에 전달하고 두 번째는 조회한 회원 객체를 재사용한다.
데이터 접근 추상화와 벤더 독립성
관계형 데이터베이스는 같은 기능도 벤더마다 사용법이 다른 경우가 많다.
단적인 예로 페이징 처리는 데이터베이스마다 달라서 사용법을 각각 배워야 한다.
결국 애플리케이션은 처음 선택한 데이터베이스 기술에 종속되고 다른 데이터베이스로 변경하기는 매우 어렵다.
JPA는 애플리케이션과 데이터베이스 사이에 추상화된 데이터 접근 계층을 제공해서 애플리케이션이 특정 데이터베이스 기술에 종속되지 않도록 한다. 만약 데이터베이스를 변경하면 JPA에게 다른 데이터베이스를 사용한다고 알려주기만 하면 된다.
표준
JPA는 자바 진영의 ORM 기술 표준이다. 앞서 이야기했듯이 표준을 사용하면 다른 구현 기술로 손쉽게 변경할 수 있다.
참고 자료 :
https://product.kyobobook.co.kr/detail/S000000935744
'백엔드 > JPA' 카테고리의 다른 글
[JPA] flush(), detach(), clear(), close(), merge() (0) | 2023.05.02 |
---|---|
[JPA] 엔티티 조회, 등록, 수정, 삭제 (0) | 2023.05.02 |
[JPA] 영속성 컨텍스트(persistence context)란? (0) | 2023.05.02 |
[JPA] 패러다임의 불일치 (0) | 2023.05.01 |
[JPA] SQL Mapper 와 ORM (1) | 2023.05.01 |