[Spring_Boot] JPQL - 반환타입 & 결과 조회 API & 파라미터 바인딩

최현석·2022년 12월 11일
0

Spring_Boot

목록 보기
24/31

🧩 객체지향 쿼리 언어(JPQL)

  • JPA는 다양한 쿼리 방법을 지원
  • JPQL - 권장, 실무사용, 거의 모든 문제 해결 가능
  • JPA Criteria - 자바코드를 짜서 JPA를 빌드해주는 generator 모음
  • QueryDSL - 권장, 실무사용
  • 네이티브 SQL - connect by ...
  • JDBC API - MyBatis, SpringJdbcTemplate

JPQL

  • JPA를 사용하면 엔티티 객체를 중심으로 개발
  • 문제는 검색 쿼리
  • 검색을 할때도 테이블이 아닌 엔티티 객체를 대상으로 검색
  • JPA는 SQL을 추상화JPQL이라는 객체 지향 쿼리 언어 제공
  • SQL과 문법 유사, select, from, where, group by, having, join.. 지원
  • JPQL은 엔티티 객체를 대상으로 쿼리
  • SQL은 데이터베이스 테이블을 대상으로 쿼리
  • Java Persistence Query Language
  • SQL을 추상화해서 특정 데이터베이스에 의존하지 않음
  • JPA는 JPQL을 분석 후, 적절한 SQL을 만들어 데이터베이스를 조회

규칙

  • 엔티티이름
    -> 테이블명 대신 엔티티명을 사용, @Entity(name = "")으로 설정 가능
    -> 지정하지 않을 시 클래스 명을 기본값으로 사용(추천)
  • 별칭은 필수
    -> JPQL은 별칭을 필수
    -> AS는 생략 가능

JpaMain7

  • 네모 박스가 JPQL 부분
  • Member 대소문자 명칭 그대로 가져온다,
  • 별칭은 필수(alias) -> 'm'
			List<Member> result =  em.createQuery(
									"select m from Member m where m.username like '%kim%' ", 
									Member.class).getResultList();
			
			for( Member member : result ) {
				System.out.println("member = " + member);
			}

JPQL문법

  • select
    select절 항목
    from절
    where절
    group by절
    having절
    order by절

  • update
    update절
    where절

  • delete
    delete절
    where절

함수

  • m => alias

  • count(m) // 회원수

  • sum(m.age) // 나이의 합

  • avg(m.age) // 평균 나이

  • max(m.age) // 최대 나이

  • min(m.age) // 최소 나이

🧩 TypedQuery, Query (반환타입)

  • TypedQuery : 반환 타입이 명확할 때 사용

TypedQuery<Member> query = ("select m from member m", Member.class)

  • name 이므로 String으로 받는다.
    TypedQuery<String> query = ("select m.username from member m", String.class)

  • Query : 반환 타입이 명확하지 않을 때 사용

Query query = ("select m.username, m.age from member m", Member.class)

JpaMain7

			// TypedQuery
			// 타입 정보가 Member로 명확할때
			TypedQuery<Member> query = 
					em.createQuery("select m from Member m",Member.class);

			// 타입정보가 String.class로 반환이 명확할 때
			TypedQuery<String> query2 = 
					em.createQuery("select m.username from Member m", String.class);

			// m.username(String), m.age(int) : 이렇게 반환타입이 명확하지 않을 때
			Query query3 = 
					em.createQuery("select m.username, m.age from Member m");

🧩 결과 조회 API

  • qeury.getResultList()
    : 결과가 하나 이상일 때 리스트 반환
    : 결과가 없으면 빈 리스트 반환
    : 빈 collection이 반환되기 때문에 ullPointerException에 대한 걱정은 안해도 된다.

  • query.getSingleResult()
    : 결과가 정확히 하나(조심), 단일 객체 반환
    : 결과가 없을경우 -> NoResultException
    : 결과가 둘 이상이면 -> NonUniqueResultException

JpaMain7

			// getResultList()
			TypedQuery<Member> query4
			 	= em.createQuery("select m from Member m", Member.class);
			List<Member> resultList = query4.getResultList();

			// 결과값 하나일 때, getSingleResult()
			TypedQuery<Member> query5
				= em.createQuery("select m from Member m where m.id = 10", Member.class);
			Member result2 = query5.getSingleResult();

파라미터 바인딩 - 이름 기준, 위치

이름기준

select m from Member m where m.username = :username
query.setParameter("username", usernameParam);

위치기준(권장하지 않음)

select m from Member m where m.username = ?1
query.setParameter(1, usernameParam);

0개의 댓글