이 글은 김영한 님의 Infrean 강의를 학습한 내용을 정리하여 작성합니다.
H2 데이터베이스 설치와 실행
- 최고의 실습용 DB
- 가볍다. (1.5M)
- 웹용 쿼리툴 제공
- MySQL, Oracle 데이터베이스 시뮬레이션 기능
- 시퀀스, AUTO INCREMENT 기능 지원
메이븐 소개
- 자바 라이브러리, 빌드 관리
- 라이브러리 자동 다운로드 및 의존성 관리
- 최근에는 그래들(Gradle)이 유명
프로젝트 생성
- 자바 8 이상
- 메이븐 설정
- groupid: jpa-basic
- artifactId: ex1-hello-jpa
- version: 1.0.0
라이브러리 추가
hibernate-entitymanager를 가져오면 hibernate에 필요한 모든 것을 사용할 수 있게 된다.
또한, h2 데이터베이스를 사용하므로 h2에 대한 내용도 dependency에 추가해준다.
Hibernate 버전 선택하기
spring.io 사이트에서 현재 사용 중인 spring 버전에 대한 Reference.Doc. 파일을 살펴보면 위와 같이 hibernate 버전을 살펴볼 수 있다.
주의!!
H2 데이터베이스는 자신이 다운받은 H2 버전과 동일하도록 한다.
JPA 설정하기 - persistence.xml
- JPA 설정 파일
- /META-INF/persistence.xml 위치
- persistence-unit name으로 이름 지정
- javax.persistence로 시작: JPA 표준 속성
- hibernate로 시작: 하이버네이트 전용 속성
※ 데이터베이스 방언
- JPA는 특정 데이터베이스에 종속되지 않는다.
- 각각의 데이터베이스가 제공하는 SQL 문법과 함수는 조금씩 다르다.
- 가변 문자: MySQL은 VARCHAR, Oracle은 VARCHAR2
- 문자열을 자르는 함수: SQL 표준은 SUBSTRING(), Oracle은 SUBSTR()
- 페이징: MySql은 LIMIT, Oracle은 ROWNUM
- 방언: SQL 표준을 지키지 않는 특정 데이터베이스만의 고유한 기능
H2라는 데이터베이스 방언을 사용하므로 알리기 위해
<property name="hibernate.dialect" value="org.hibernate.dialect.H2Dialect"/>
내용을 추가해준다.
-> 이를 통해 JPA는 알아서 내용을 번역해서 사용하게 된다.
- hibernate.dialect 속성에 지정
- H2 : org.hibernate.dialect.H2Dialect
- Oracle 10g : org.hibernate.dialect.Oracle10gDialect
- MySQL : org.hibernate.dialect.MySQL5InnoDBDialect
- 하이버네이트는 40가지 이상의 데이터베이스 방언 지원
'JPA > JPA 시작하기' 카테고리의 다른 글
Hello JPA - 애플리케이션 개발 (0) | 2022.07.15 |
---|