http://www.h2database.com/
적은 용량, 웹콘솔환경, 시퀀스,AUTO INCREMENT들을 지원하기때문에 실습용 DB로 사용하기 좋다.
<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>
hibernate-entitymanager : 하이버네이트 코어 라이브러리, javax.persistence-api등이 들어가있다. 특히 하이버네이트가 JPA의 구현체이기때문에, javax.persistence-api에는 jpa인터페이스가 모아져있다.
h2 : H2 데이터베이스 드라이버
버전 선택방법
강의에서는 스프링을 이용하지 않기 때문에 버전에 대한 큰 제약은 없지만, 실제 개발에서는 스프링과 엮어 사용하기에 버전 구분해줘야한다..
따라서 스프링 공식사이트에서 스프링부트의 버전을 확인하여 라이브러리 버전을 선택해야한다.
<?xml version="1.0" encoding="UTF-8"?>
<!-- jpa버전 정보-->
<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">
<!-- name으로 이름 지정 -->
<persistence-unit name="hello">
<properties>
<!-- 필수 속성 -->
<!-- 데이터베이스가 필수적이기 때문에 DB드라이버 정보를 필수적으로 넣어준다 -->
<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>
JPA는 특정 데이터베이스에 종속되지 않는다.
각 데이터베이스마다의 고유한 기능이나, 문법이 있는데, 이것을 데이터베이스 방언이라한다.
따라서 JPA를 설정할때 사용하는 데이터베이스에 따라 설정해줘야한다.
JPA 설정파일에서 설정 가능
• hibernate.dialect 속성에 지정
• H2 : org.hibernate.dialect.H2Dialect
• Oracle 10g : org.hibernate.dialect.Oracle10gDialect
• MySQL : org.hibernate.dialect.MySQL5InnoDBDialect
• 하이버네이트는 40가지 이상의 데이터베이스 방언 지원