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
- JPQL
- QueryDSL
- 김영한
- 자바
- 스프링 핵심 기능
- 백준
- jpa
- spring
- 스프링
- 인프런
- java
- 그리디
- springdatajpa
- db
- SpringBoot
- 알고리즘
- Spring Boot
- http
- pointcut
- Greedy
- Proxy
- Android
- Servlet
- transaction
- 스프링 핵심 원리
- Thymeleaf
- AOP
- Exception
- JDBC
- kotlin
Archives
- Today
- Total
개발자되기 프로젝트
객체지향 쿼리 언어 본문
1. JPA는 다양한 쿼리 방법을 지원
- JPQL
- JPA Criteria
- QueryDLS
- 네이티브 SQL
- JDBC API 직접 사용, MyBatis, SpringJdbcTemplate 함께 사용
2. JPQL
- 가장 단순한 조회 방법
- EntityManager.find()
- 객체 그래프 탐색(a.getB().getC())
- 만약 나이가 18살 이상인 회원을 모두조회하는 경우는...?
- JPA를 사용하면 엔티티 객체를 중심으로 개발
- 문제는 검색 쿼리임
- 검색을 할 때에도 테이블이 아닌 엔티티 객체를 대상으로 검색
- 모든 DB데이터를 객체로 변환해서 검색하는 것은 불가능!!
- 매플리케이션이 필요한 데이터만 DB에서 불러오려면 결국 검색 조건이 포함된 SQL이 필요해.
- 그래서 JPA는 SQL을 추상화한 JPQL이라는 객체 지향 쿼리언어를 제공함
- SQL문법과 유사, SELECT, FROM, WHERE, GROUP BY, HAVING, JOIN 지원
- JPQL은 엔티티 객체를 대상으로 쿼리
- SQL은 데이터베이스 테이블을 대상으로 쿼리
- 예시
List<Member> resultList = em.createQuery("select m from Member m where m.userName like '%kim%'", Member.class ).getResultList();
- 작성한 JPQL이 SQL로 번역되어 실행되었다.
Hibernate: /* select m from Member m where m.userName like '%kim%' */ select member0_.MEMBER_ID as member_i1_6_, member0_.city as city2_6_, member0_.street as street3_6_, member0_.zipcode as zipcode4_6_, member0_.endDate as enddate5_6_, member0_.startDate as startdat6_6_, member0_.TEAM_ID as team_id8_6_, member0_.USERNAME as username7_6_ from Member member0_ where member0_.USERNAME like '%kim%'
2. Criteria 소개
- 동적쿼리
-
//Criteria 사용 준비 CriteriaBuilder cb = em.getCriteriaBuilder(); CriteriaQuery<Member> query = cb.createQuery(Member.class); //루트 클래스 (조회를 시작할 클래스) Root<Member> m = query.from(Member.class); //쿼리 생성 CriteriaQuery<Member> cq = query.select(m).where(cb.equal(m.get("userName"),"kim")); List<Member> resultList = em.createQuery(cq).getResultList();
-
Hibernate: /* select generatedAlias0 from Member as generatedAlias0 where generatedAlias0.userName=:param0 */ select member0_.MEMBER_ID as member_i1_6_, member0_.city as city2_6_, member0_.street as street3_6_, member0_.zipcode as zipcode4_6_, member0_.endDate as enddate5_6_, member0_.startDate as startdat6_6_, member0_.TEAM_ID as team_id8_6_, member0_.USERNAME as username7_6_ from Member member0_ where member0_.USERNAME=?
- 복잡해지면 어려워짐...
- 자바코드로 직접 짜기 때문에 오타나 컴파일 에러를 잡아줌.
- 하지만 동적 쿼리를 생성하기 용이함.
-
//Criteria 사용 준비 CriteriaBuilder cb = em.getCriteriaBuilder(); CriteriaQuery<Member> query = cb.createQuery(Member.class); //루트 클래스 (조회를 시작할 클래스) Root<Member> m = query.from(Member.class); //쿼리 생성 CriteriaQuery<Member> cq = query.select(m); String userName = "sdfsdf"; if(userName != null){ cq = cq.where(cb.equal(m.get("userName"), "kim")); } List<Member> resultList = em.createQuery(cq).getResultList(); tx.commit();
- 근데 안써
- 유지보수하기가 어려워....ㅎㅎ후ㅜㅜㅜㅜㅜ
- 문자가 아닌 자바코드로 JPQL을 작성할 수 있음
- JPQL 빌더 역할
- JPA 공식 기능
- 너~~무 복잡하고 실용성 없음.
- Criteria 대신에 QueryDSL 사용 권장.
3. QueryDSL 소개
- 문자가 아닌 자바코드로 JPQL을 작성할 수 있음
- JPQL 빌더 역할
- 컴파일 시점에 문법 오류를 찾을 수 있음
- 동적쿼리 작성 편리함
- 단순하고 쉬움
- 실무 사용 권장.
4. 네이티브 SQL 소개
- JPA가 제공하는 SQL을 직접 사용하는 기능
- JPQL로 해결할 수 없는 특정 데이터베이스에 의존적인 기능
em.createNativeQuery("select MEMBER_ID, city, street, zipcode, USERNAME from MEMBER").getResultList();
5. JDBC 직접 사용, Spring JdbcTemplate 등
- JPA를 사용하면서 JDBC 커넥션을 직접 사용하거나, 스프링 JdbcTemplate, 마이바티스등을 함께 사용 가능
- 단 영속성 컨텍스트를 적절한 시점에 강제로 플러시 필요
- 예) JPA를 우회해서 SQL을 실행하기 직전에 영속성 컨텍스트 수동 플러시
6. Github : 210814 쿼리 언어
'인프런 > [인프런] 자바ORM 표준 JPA 프로그래밍' 카테고리의 다른 글
JPQL 프로젝션 (0) | 2021.08.16 |
---|---|
JPQL 기본 문법과 기능 (0) | 2021.08.15 |
[예제] 값 타입 매핑 (0) | 2021.08.14 |
값 타입 (0) | 2021.08.13 |
값 타입 비교 (0) | 2021.08.13 |
Comments