728x90 반응형 자바/JPA30 [JPA/Java] JPQL 벌크 연산 재고가 10개 미만인 모든 상품의 가격을 10% 올리려면 어떻게 해야할까? JPA 변경 감지 기능으로 실행하려면 너무 많은 SQL이 실행되어야 한다. (1) 재고가 10개 미만인 상품을 리스트로 조회한다. (2) 상품 엔티티의 가격을 10% 증가한다 (3) 트랜잭션 커밋 시점에 변경감지가 동작한다. 변경된 데이터가 100건이라면 100번의 UPDATE SQL이 실행될 것이다. 벌크 연산은 쿼리 한 번으로 여러 테이블 로우를 변경한다(엔티티) executeUpdate()의 결과는 영향받은 엔티티의 수를 반환하는데, UPDATE, DELETE 쿼리를 지원한다 INSERT(insert into .. select, 하이버네이트 지원) String qlString = "update Product p " + "se.. 2023. 5. 11. [JPA/Java] JPQL Named 쿼리 - 어노테이션, XML Named 쿼리는 정적 쿼리이다. 미리 정의해서 이름을 부여해두고 사용하는 JPQL이다. 주로 어노테이션이나 XML에 정의해두고 애플리케이션 로딩 시점에 초기화 후 재사용한다. 애플리케이션 로딩 시점에 쿼리를 검증한다. (1) 어노테이션에서 사용하는 방법 Member.java package jpql; import javax.persistence.*; @Entity @NamedQuery( name = "Member.findByUsername", query = "select m from Member m where m.username = :username" ) public class Member { @Id @GeneratedValue private Long id; public MemberType getType.. 2023. 5. 11. [JPA/Java] JPQL 엔티티 직접 사용 JPQL에서 엔티티를 직접 사용하면 SQL에서 해당 엔티티의 기본 키 값을 사용한다. [JPQL] jpql = "SELECT count(m.id) FROM Member m"; // 엔티티의 아이디를 사용 jpql = "SELECT count(m) FROM Member m"; // 엔티티를 직접 사용 [SQL] (위의 JPQL 둘다 같은 SQL을 실행) SELECT count(m.id) as cnt FROM Member m 엔티티를 파라미터로 전달 시 String jpql = "select m from Member m where m = :member"; List resultList = em.createQuery(jpql) .setParameter("member", member) .getResultList(.. 2023. 5. 11. [JPA/Java] JPQL 다형성 쿼리 - TYPE, TREAT 다형성 쿼리로는 TYPE, TREAT이 있다. TYPE 예시 예시) Item 중에 Book, Movie를 조회하라 [JPQL] jpql = "SELECT i FROM Item i WHERE type(i) IN (Book, Movie)"; [SQL] SELECT i FROM i WHERE i.DTYPE in (‘B’, ‘M’) TREAT(JPA 2.1) TREAT은 자바의 타입 캐스팅과 유사하다. 상속 구조에서 부모 타입을 특정 자식 타입으로 다룰 때 사용한다. FROM, WHERE, SELECT(하이버네이트 지원) 에서 사용할 수 있다. 예시) 부모인 Item과 자식 Book이 있다. [JPQL] jpql = "SELECT i FROM Item i WHERE treat(i as Book).author =.. 2023. 5. 11. [JPA/Java] JPQL 패치 조인의 한계 - 글로벌 배치 패치 사이즈, @BatchSize JPQL 패치 조인의 한계 ① 패치 조인 대상에는 별칭을 줄 수 없다. - 하이버네이트는 가능하나, 가급적 사용하지 않는다. jpql = "select t from Team t join fetch t.members m"; // 패치 조인 대상에는 Alias를 주면 안된다. 패치 조인은 연관관계를 다 끌고 오는 건데, 별칭을 줘서 데이터를 누락시켜서 가져오는 가능성도 있다. 패치 조인에서 별칭을 쓰지 않아야 하는 이유는 → 데이터의 정합성이나 객체 사상이 안맞을 가능성이 높기 때문에 쓴다면 다대일 관계로 만들고 쓰는게 좋다. jpql = "select m from Member m join fetch m.team"; ② 둘 이상의 컬렉션은 패치 조인을 사용할 수 없다. → 데이터 정합성 문제 때문에 (일대다.. 2023. 5. 11. [JPA/Java] JPQL fetch join (패치 조인) JPQL에는 fetch 조인이라는게 있는데 이게 실무에서 정말정말 중요하다고 한다. 패치 조인(fetch)은 SQL 조인의 종류가 아닌데, JPQL에서 성능 최적화를 위해서 제공하는 기능이다. 연관된 엔티티나 컬렉션을 SQL 한 번에 함께 조회하는 기능을 제공한다. "join fetch" 와 같이 명령어를 사용한다. 패치 조인은 LEFT JOIN FETCH [OUTER 생략 가능] / INNER JOIN FETCH 와 같이 조인 경로를 쓰면 된다. 엔티티 패치 조인은 회원을 조회하면서 연관된 팀도 함께 조회한다. (SQL을 날리는 트랜잭션 한 번에) SQL을 보면 회원 뿐만 아니라 팀(T.*)도 함께 SELECT 된다. [JPQL] select m from Member m join fetch m.team.. 2023. 5. 10. 이전 1 2 3 4 5 다음 728x90 반응형