02 Hello JPA

02 Hello JPA - 애플리케이션 개발
AKENDEV's avatar
Mar 27, 2024
02 Hello JPA

데이터 베이스 방언

  • JPA는 특정 데이터베이스에 종속이지 않다.
  • 각각의 데이터베이스가 제공하는 SQL 문법과 함수는 조금씩 다름
    • 가변 문자: MySQL은 VARCHAR, Oracle은 VARCHAR2
    • 문자열을 자르는 함수: SQL 표준은 SUBSTRING(), Oracle은 SUBSTR()
    • 페이징: MySQL은 LIMIT , Oracle은 ROWNUM
  • 방언: SQL 표준을 지키지 않는 특정 데이터베이스만의 고유한 기능
  • hibernate.dialect 속성에 지정
    • H2 : org.hibernate.dialect.H2Dialect
    • Oracle 10g : org.hibernate.dialect.Oracle10gDialect
    • MySQL : org.hibernate.dialect.MySQL5InnoDBDialect
  • 하이버네이트는 40가지 이상의 데이터베이스 방언 지원

persistence.xml

<property name="javax-persistence jdbc-driver" value="org.h2.Driver"/> <property name="javax-persistence-jdbc.user" value="sa"/> <property name="javax-persistence.jdbc-password" value=""/> <property name="javax.persistence.jdbc.url" value="jdbc:h2:tcp://localhost"/> <property name="hibernate.dialect" value="org.hibernate.dialect.H2Dialect"/> <!-- 옵션 --> <property name="hibernate.show_sql" value="true"/> <property name="hibernate.format_sql" value="true" /> <property name="hibernate.use_sql_comments" value="true"/> <!-- <property name="hibernate.hbm2ddl.auto" value="create" /> -->

JPA 구동 방식

notion image

주의

  • 엔티티 매니저 팩토리는 하나만 생성해서 애플리케이션 전체에 서 공유
  • 엔티티 매니저는 쓰레드간에 공유하지 않는다. (사용하고 버려야 한다). em.close();
    • DB Connection Pool 관리
  • JPA의 모든 데이터 변경은 트랜잭션 안에서 실행

JPQL

객체 지향 SQL
  • JPA를 사용하면 엔티티 객체를 중심으로 개발
  • 문제는 검색 쿼리
    • 검색을 할 때도 테이블이 아닌 엔티티 객체를 대상으로 검색
    • 모든 DB 데이터를 객체로 변환해서 검색하는 것은 불가능
    • 애플리케이션이 필요한 데이터만 DB에서 불러오려면 결국 검 색 조건이 포함된 SQL이 필요
  • JPA는 SQL을 추상화한 JPQL이라는 객체 지향 쿼리. 언어 제공
  • SQL과 문법 유사, SELECT, FROM, WHERE, GROUP BY, HAVING, JOIN 지원
  • JPQL은 엔티티 객체를 대상으로 쿼리
    • List<Member> members = em.createQuery("select m from Member m", Member.class) .setFirstResult(5) // offset .setMaxReult(8) // limit .getResultList();
  • SQL은 데이터베이스 테이블을 대상으로 쿼리
  • JPQL의 장점
    • 테이블이 아닌 객체를 대상으로 검색하는 객체 지향 쿼리
    • SQL을 추상화해서 특정 데이터베이스 SQL에 의존하지 않는다.
      • = 방언을 변경 하더라도 JPQL을 변경할 필요가 없다.
Share article

akendev's Archive