Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 분석함수
- 시큐어코딩
- 스프링 부트와 JPA
- 이것이자바다
- 자바연습문제
- 스프링 핵심원리
- 제네릭
- JPA
- 불친절한SQL프로그래밍
- 인프런
- Numpy
- java
- 김영한
- 자바의정석 연습문제
- docker
- Python
- 항해플러스
- 자바공부
- 스프링입문
- Java의정석
- REGEXP_SUBSTR
- 불친절한 SQL 프로그래밍
- 서블릿
- inflearn
- 항해플러스 백엔드
- 스프링
- 스프링MVC
- Secure Coding
- Spring
- 자바의정석
Archives
- Today
- Total
Continuous Challenge
3. JPA 시작하기 본문
728x90
728x90
프로젝트 생성
- H2 데이터베이스 설치 및 실행 (persistence.xml 작성)
- Maven Project 생성 (Java 8) (pom.xml 작성)
데이터베이스 방언
- JPA는 특정 데이터베이스에 종속 X
- 각각의 데이터베이스가 제공하는 SQL 문법과 함수는 조금씩 다름
- 가변 문자 : MySQL은 VARCHAR, Oracle은 VARCHAR2
- 문자열을 자르는 함수 : SQL은 표준은 SUBSTRING(), Oracle은 SUBSTR()
- 페이징 : MySQL은 LIMIT, Oracle은 ROWNUM - 방언 : SQL 표준을 지키지 않는 특정 데이터베이스만의 고유한 기능
- hibernate.dialect 속성에 지정
주의할 점
- 엔티티 매니저 팩토리는 하나만 생성해서 애플리케이션 전체에서 공유
- 엔티티 매니저는 쓰레드간에 공유X (사용하고 버려야 한다).
- JPA의 모든 데이터 변경은 트랜잭션 안에서 실행
JPQL
- JPA를 사용하면 엔티티 객체를 중심으로 개발
- 모든 DB 데이터를 객체로 변환해서 검색하는 것은 불가능
→ 애플리케이션이 필요한 데이터만 DB에서 불러오려면 결국 검색 조건이 포함된 SQL이 필요 - JPA는 SQL을 추상화한 JPQL이라는 객체 지향 쿼리 언어 제공 (특정 데이터베이스 SQL에 의존X)
- SQL과 문법 유사. SELECT, FROM, WHERE, GROUP BY, HAVING, JOIN 지원
- JPQL은 엔티티 객체를 대상으로 쿼리 (SQL은 데이터베이스 테이블을 대상으로 쿼리)
- JPQL을 한마디로 정의하면 객체 지향 SQL
정리
- JPA는 항상 EntityManagerFactory를 만들어야 한다.
- EntityManagerFactory : 데이터베이스 당 한 개씩 묶여서 돌아간다.
- persistence.xml의 설정 정보를 읽어와서 생성한다. - 고객의 요청이 올 때마다 EntityManager 를 통해 작업해야 한다.
- JPA의 모든 데이터 변경은 transaction 내에서 발생해야 한다. (EntityTransaction)
- 자원을 모두 사용한 후에는 닫아줘야 한다. (close())
728x90
728x90
'Spring > 자바 ORM 표준 JPA 프로그래밍 - 기본편' 카테고리의 다른 글
4. 엔티티 매핑 - 필드와 컬럼 매핑 (0) | 2022.03.25 |
---|---|
4. 엔티티 매핑 - 객체와 테이블 매핑 (0) | 2022.03.25 |
3. 영속성 관리 - 내부 동작 방식 (0) | 2022.03.24 |
2. JPA 소개 (0) | 2022.03.23 |
1. 강좌 소개 (0) | 2022.03.22 |
Comments