일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- JDBC
- QueryDSL
- AOP
- 자바
- Greedy
- Exception
- jpa
- java
- spring
- kotlin
- http
- Proxy
- 스프링
- 스프링 핵심 기능
- db
- Thymeleaf
- 인프런
- Spring Boot
- 알고리즘
- transaction
- pointcut
- 김영한
- JPQL
- 스프링 핵심 원리
- SpringBoot
- 그리디
- Android
- 백준
- springdatajpa
- Servlet
- Today
- Total
목록컬렉션 조회 최적화 (2)
개발자되기 프로젝트
다 조인시켜서 한방쿼리로 가져오자. 1. OrderFlatDto Order와 OrderItem을 join해서 DTO로 한번에 가져올 예정. DB에서 join하면 한줄로 쭉 join 되듯이 데이터 구조를 맞춤. @Data public class OrderFlatDto { //order private Long orderId; private String name; private LocalDateTime orderDate; private OrderStatus orderStatus; private Address address; //orderItem private String itemName; private int orderPrice; private int count; public OrderFlatDto(Long ..
1. 최적화 public List findAllByDto_optimization() { List result = findOrders(); List orderIds = toOrderIds(result); Map orderItemMap = findOrderItemMap(orderIds); //메모리에 map을 올려놓고 찾아서 꽂아넣기. result.forEach(o -> o.setOrderItems(orderItemMap.get(o.getOrderId()))); return result; } private List toOrderIds(List result) { List orderIds = result.stream().map(o -> o.getOrderId()) .collect(Collectors.toList..