본 게시글은 김영한 님의 자바 ORM 표준 JPA 프로그래밍 - 기본편 을 정리한 내용입니다.
Maven 으로 새 프로젝트를 생성한다.
pom.xml
<dependencies>
     <!-- JPA 하이버네이트 -->
     <dependency>
         <groupId>org.hibernate</groupId>
         <artifactId>hibernate-entitymanager</artifactId>
         <version>5.3.10.Final</version>
     </dependency>
     <!-- H2 데이터베이스 -->
     <dependency>
         <groupId>com.h2database</groupId>
         <artifactId>h2</artifactId>
         <version>1.4.199</version>
     </dependency>
 </dependencies>JPA(인터페이스)의 구현체로 하이버네이트, 데이터베이스로 H2를 선택했다.
H2 데이터베이스 특징
- 빠르고 작은 크기의 RDBMS(관계형 데이터베이스)
- 임베디드 및 서버모드(영구 데이터베이스), 인 메모리 데이터베이스
 => 주로 메모리에 데이터를 저장, 디스크에 데이터를 저장할 수도 있음
- MySQL, Oracle 데이터베이스 시뮬레이션 기능
- 시퀀스, AUTO INCREMENT 기능 지원
JPA 설정 - persistence.xml
- JPA 설정 파일
- main/resources/META-INF/persistence.xml 위치
- persistence-unit name으로 이름 지정
- javax.persistence로 시작: JPA 표준 속성
- hibernate로 시작: 하이버네이트 전용 속성
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.2"
             xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_2.xsd">
    <persistence-unit name="hello">
        <properties>
            <!-- 필수 속성 -->
            <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/~/test"/>
            <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" />-->
        </properties>
    </persistence-unit>
</persistence>데이터베이스 방언
<property name="hibernate.dialect" value="org.hibernate.dialect.H2Dialect"/>- JPA는 특정 데이터베이스에 종속 X
- 각각의 데이터베이스가 제공하는 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.MySQL5Dialect
 
- 하이버네이트는 40가지 이상의 데이터베이스 방언 지원
'JPA' 카테고리의 다른 글
| [JPA] 상속관계 매핑, @MappedSuperclass (0) | 2022.07.28 | 
|---|---|
| [JPA] 다대일,일대다,일대일,다대다 (@ManyToOne,@OneToMany,@OneToOne,@ManyToMany) (0) | 2022.07.28 | 
| [JPA] 연관관계 매핑 기초 (0) | 2022.07.28 | 
| [JPA] 엔티티 매핑 (0) | 2022.07.28 | 
| [JPA] JPA 소개 (0) | 2022.07.28 | 
 
										
									 
										
									 
										
									 
										
									
댓글