이 카테고리는 인프런 김영한님의 JPA 강의를 보고 정리하는 공간입니다.
JPA란?
정의
- Java Persistence API의 약자로 자바진영의 ORM 기술 표준이다
- 따지고 보면 JPA는 여러 인터페이스의 모음이다. 그 인터페이스들을 구현한 구현체로 여러가지가 있는데 그 중 가장 대표적인 것이 Hibernate(자바 환경에서 객체-관계 모델 매핑 솔루션)이다.
ORM?
- Object Relational Mapping의 약자로 기존까지의 객체 vs 관계형 데이터베이스 사이의 패러다임을 해결해준다.
- 객체는 객체대로 설계, RDB는 RDB대로 설계를 하고 이 둘 사이의 매핑을 도와주는 프레임워크라고 할 수 있겠다.
동작
JPA는 애플리케이션과 JDBC사이에서 동작한다.
- 우리가 JPA에게 명령을 내리면 JPA는 적합한 SQL문을 생성하고 JDBC를 사용하여 DB와 상호작용한다. 즉 개발자가 직접 쿼리를 작성하지 않아도 된다!
저장
- JPA에게 객체를 넘기면 JPA가 객체를 분석하고 INSERT 쿼리를 생성한다.
조회
- 조회도 마찬가지다.
왜 JPA를 써야하는가?
- SQL 중심 개발이 아닌 객체 중심 개발
- 생산성 향상
- 유지보수
- 패러다임 불일치 해결
- 성능
- 데이터 접근 추상화와 벤더 독립성
- 표준
이라는 장점이 있다.
생산성
JPA는 CRUD가 이미 다 정의돼있다. 너무 간편.
- 저장: jpa.persist(member)
- 조회: Member member = jpa.find(memberId)
- 수정: member.setName(“변경할 이름”)
- 삭제: jpa.remove(member)
특시 수정연산의 경우 자바 컬렉션의 데이터를 다루듯 그냥 set으로 값만 바꿔주면 마법처럼 수정이 이루어진다. 정확한 원리는 추후의 포스팅에서 다루겠다.
유지보수
기존에는 필드에 변경사항이 있을 경우 모든 SQL을 수정해야 했다.
하지만 JPA에선 필드만 수정하면 된다. SQL은 JPA가 알아서 처리해주기때문.
성능
JPA는 애플리케이션과 JDBC 사이에 존재한다. 즉 중간에서 여러 기능(캐싱, 쓰기지연, 즉시로딩, 지연로딩 등)을 수행해 줄 수있기에 성능 최적화에 특화돼있다. 이것들에 대한 자세한 내용 역시 이후의 포스팅에서 다루겠다.
참고:
'JPA' 카테고리의 다른 글
[JPA] 다양한 연관관계 (2) | 2021.07.24 |
---|---|
[JPA] 연관관계 매핑 (0) | 2021.07.21 |
[JPA] 엔티티 매핑 (0) | 2021.07.19 |
[JPA] 영속성 관리 (0) | 2021.07.17 |