ORM?
- Object-relational mapping(객체 관계 매핑)
- 객체는 객체대로 설계
- 관계형 데이터베이스는 관계형 데이터베이스대로 설계
- ORM 프레임워크가 중간에서 매핑
- 대중적인 언어에는 대부분 ORM 기술이 존재
저장 : jpa.persist(member)
조회 : Member member = jpa.find(memberid)
수정 : member.setName("변경할 이름")
삭제 : jpa.remove(member)
1차 캐시와 동일성 보장
----- SQL 1번만 실행 -----
String memberId = "100";
Member m1 = jpa.find(Member.class, memberId); // SQL
Member m2 = jpa.find(Member.class, memberId); // 캐시
println(m1 == m2) // true
트랜잭션을 지원하는 쓰기 지연
transaction.begin(); // [트랜잭션] 시작
em.persist(meberA);
em.persist(meberB);
em.persist(meberC);
// 여기까지 INSERT SQL을 데이터베이스에 보내지 않는다.
// 커밋하는 순간 데이터베이스에 INSERT SQL을 모아서 보낸다.
transaction.commit(); // [트랜잭션] 커밋
지연 로딩과 즉시 로딩