일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- Proxy
- Spring Boot
- java
- QueryDSL
- http
- jpa
- transaction
- 인프런
- 자바
- kotlin
- Thymeleaf
- 알고리즘
- 스프링
- AOP
- Exception
- spring
- db
- 스프링 핵심 원리
- 스프링 핵심 기능
- springdatajpa
- Greedy
- pointcut
- JDBC
- 김영한
- 그리디
- 백준
- Android
- JPQL
- SpringBoot
- Servlet
- Today
- Total
목록벌크 연산 (2)
개발자되기 프로젝트
1. 쿼리 한번으로 대량 데이터 수정 : 벌크 연산 벌크연산은 영속성 컨텍스트를 거치지 않고 바로 DB에 반영함 즉 벌크연산 후 영속성 컨텍스트와 DB가 다르다. 벌크 연산 후 영속성 컨텍스트를 초기화 해주자. @Test public void bulkUpdate(){ /** * member1 = 10 -> 비회원 * member2 = 20 -> 비회원 * member3 = 30 -> 유지 * member4 = 40 -> 유지 */ long count = queryFactory .update(member) .set(member.username, "비회원") .where(member.age.lt(28)) .execute(); em.flush(); em.clear(); } update Member member..
1. 벌크연산이란??? 한 건 딱 찍어서 하는 UPDATE, DELTE제외하고 나머지 재고가 10개 미만인 모~든 상품의 가격을 10% 인상하려면? JPA 변경 감지 기능으로 실행하려면 너무 많은 SQL이 실행됨 재조가 10개 미만인 상품을 리스트로 조회 상품 엔티티의 가격을 10%인상 트랜잭션 커밋 시점에 변경감지 동작 변경된 데이터가 1000이면 1000번 UPDATE SQL날라감 ㄷㄷㄷ JPA도 쿼리 한방에 벌크 연산하도록 지원함 2. 예제 쿼리 한 방에 여러 테이블 로우 변경(엔티티) executeUpdate()의 결과는 영향받은 엔티티의 수를 반환함 UPDATE, DELETE 지원 INSERT(insert into... select, 하이버네이트 지원) int resultCount = em.cr..