-
JPA 세팅 및 기본 실습김영한(인프런 강의)/자바 ORM 표준 JPA 프로그래밍 2020. 9. 28. 14:32반응형
JPA 개발 세팅
1. 사용 DB는 H2를 사용
2) 최고의 실습용 DB
3) 가볍다.(1.5M)
4) 웹용 쿼리툴 제공
5) MySQL, Oracle 데이터베이스 시뮬레이션 기능
6) 시퀀스, AUTO INCREMENT 기능 지원
2. Maven 사용
2) 자바 라이브러리, 빌드 관리
3) 라이브러리 자동 다운로드 및 의존성 관리
4) 최근에는 그래들(Gradle)이 점점 유명
3. 프로젝트 생성
4. JPA 설정하기 - persistence.xml
1) JPA 설정 파일
2) /META-INF/persistence.xml 위치
3) persistence-unit name으로 이름 지정
4) javax.persistence로 시작: JPA 표준 속성
5) hibernate로 시작: 하이버네이트 전용 속성
show_sql - sql 문 보기
format_sql - SQL문 이쁘게 보기
use_sql_comments - JPA가 어떤 쿼리에 접속했는지
batch_size - 한꺼번에 쿼리를 보낼게 몇개인지
<?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.jdbc.batch_size" value="10"/> <!--<property name="hibernate.hbm2ddl.auto" value="create" />--> </properties> </persistence-unit> </persistence>
JPA와 데이터 베이스
1. JPA는 특정 데이터베이스에 종속 X
2. 각각의 데이터베이스가 제공하는 SQL 문법과 함수는 조금씩 다름
1) 가변 문자: MySQL은 VARCHAR, Oracle은 VARCHAR2
2) 문자열을 자르는 함수: SQL 표준은 SUBSTRING(), Oracle은 SUBSTR()
3) 페이징: MySQL은 LIMIT , Oracle은 ROWNUM
3. 방언: SQL 표준을 지키지 않는 특정 데이터베이스만의 고유한 기능
1) hibernate.dialect 속성에 지정
● H2 : org.hibernate.dialect.H2Dialect
● Oracle 10g : org.hibernate.dialect.Oracle10gDialect
● MySQL : org.hibernate.dialect.MySQL5InnoDBDialect
2) 하이버네이트는 40가지 이상의 데이터베이스 방언 지원
실습 시작
1. JPA 구동방식
2. 코드작성
1) 기본 코드 작성
@Entity: JPA가 관리할 객체
@Id: 데이터베이스 PK와 매핑import javax.persistence.Entity; import javax.persistence.Id; @Entity public class Member { @Id private Long id; private String name; public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
import javax.persistence.EntityManager; import javax.persistence.EntityManagerFactory; import javax.persistence.Persistence; public class JpaStudyApplication { public static void main(String[] args) { EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello"); EntityManager em = emf.createEntityManager(); // code em.close(); emf.close(); } }
3. JPA 사용시 주의할점
1) 엔티티 매니저 팩토리는 하나만 생성해서 애플리케이션 전체에 서 공유
2) 엔티티 매니저는 쓰레드간에 공유X (사용하고 버려야 한다).
3) 엔티티 매니저는 JDBC Connection을 물고 있기 때문에 트랜잭션 후 닫아줘야 한다.
4) JPA의 모든 데이터 변경은 트랜잭션 안에서 실행
4. 실습
1) H2 DB에 들어가서 아래와같이 테이블 생성
- H2는 localhost:8082로 들어갈 수 있음
2) 회원 저장
import javax.persistence.EntityManager; import javax.persistence.EntityManagerFactory; import javax.persistence.EntityTransaction; import javax.persistence.Persistence; public class JpaStudyApplication { public static void main(String[] args) { EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello"); EntityManager em = emf.createEntityManager(); EntityTransaction tx = em.getTransaction(); //트랜잭션 시작 tx.begin(); try { Member member = new Member(); member.setId(1L); member.setName("JinSeok"); //JPA에 담기 em.persist(member); //commit tx.commit(); }catch (Exception e) { tx.rollback(); }finally { em.close(); } emf.close(); } }
2) 회원 조회/삭제
import javax.persistence.EntityManager; import javax.persistence.EntityManagerFactory; import javax.persistence.EntityTransaction; import javax.persistence.Persistence; public class JpaStudyApplication { public static void main(String[] args) { EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello"); EntityManager em = emf.createEntityManager(); EntityTransaction tx = em.getTransaction(); //트랜잭션 시작 tx.begin(); try { // 조회 Member findMember = em.find(Member.class,1L); System.out.println("fineMember.id : " + findMember.getId()); System.out.println("fineMember.name : " + findMember.getName()); //삭제 em.remove(findMember); tx.commit(); }catch (Exception e) { tx.rollback(); }finally { em.close(); } emf.close(); } }
3) 회원 수정
- tx.comit() 시점에 데이터가 변경될 시 JPA가 변화된 것을 감지하여 DB에 수정한 값을 넣어준다.
import javax.persistence.EntityManager; import javax.persistence.EntityManagerFactory; import javax.persistence.EntityTransaction; import javax.persistence.Persistence; public class JpaStudyApplication { public static void main(String[] args) { EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello"); EntityManager em = emf.createEntityManager(); EntityTransaction tx = em.getTransaction(); //트랜잭션 시작 tx.begin(); try { // 조회 Member findMember = em.find(Member.class,1L); findMember.setName("hello"); tx.commit(); }catch (Exception e) { tx.rollback(); }finally { em.close(); } emf.close(); } }
JPQL
1. JPQL란?
1) 가장 단순한 조회 방법
● EntityManager.find()
● 객체 그래프 탐색(a.getB().getC())
2. JPQL 설명
1) JPA를 사용하면 엔티티 객체를 중심으로 개발
2) 문제는 검색 쿼리
3) 검색을 할 때도 테이블이 아닌 엔티티 객체를 대상으로 검색
4) 모든 DB 데이터를 객체로 변환해서 검색하는 것은 불가능
5) 애플리케이션이 필요한 데이터만 DB에서 불러오려면 결국 검 색 조건이 포함된 SQL이 필요
6) JPA는 SQL을 추상화한 JPQL이라는 객체 지향 쿼리 언어 제공
7) SQL과 문법 유사, SELECT, FROM, WHERE, GROUP BY, HAVING, JOIN 지원
8) JPQL은 엔티티 객체를 대상으로 쿼리
9) SQL은 데이터베이스 테이블을 대상으로 쿼리
10) 테이블이 아닌 객체를 대상으로 검색하는 객체 지향 쿼리
11) SQL을 추상화해서 특정 데이터베이스 SQL에 의존X
12) JPQL을 한마디로 정의하면 객체 지향 SQL
3. 실습
1) 조회
- FirstResult와 MaxResuts 는 페이징 처리하는 부분
import javax.persistence.EntityManager; import javax.persistence.EntityManagerFactory; import javax.persistence.EntityTransaction; import javax.persistence.Persistence; public class JpaStudyApplication { public static void main(String[] args) { EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello"); EntityManager em = emf.createEntityManager(); EntityTransaction tx = em.getTransaction(); //트랜잭션 시작 tx.begin(); try { List<Member> result = em.createQuery("select m from Member as m", Member.class) .setFirstResult(1) .setMaxResults(2) .getResultList(); for(Member member : result) { System.out.println("member.name = " + member.getName()); } }catch (Exception e) { tx.rollback(); }finally { em.close(); } emf.close(); } }
반응형'김영한(인프런 강의) > 자바 ORM 표준 JPA 프로그래밍' 카테고리의 다른 글
엔티티 매핑 - 필드와 컬럼 매핑 (0) 2020.10.02 엔티티 매핑 - 데이터베이스 스키마 자동 생성 (0) 2020.09.29 엔티티 매핑 - 객체와 테이블 매핑 (0) 2020.09.29 영속성 관리 - 내부 동작 방식 (0) 2020.09.29 JPA은무엇인가? (0) 2020.09.28