일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- Servlet
- 자바
- db
- http
- 알고리즘
- springdatajpa
- jpa
- Android
- Exception
- JDBC
- 스프링 핵심 기능
- QueryDSL
- spring
- Proxy
- 스프링
- pointcut
- kotlin
- 스프링 핵심 원리
- java
- transaction
- Greedy
- 인프런
- 김영한
- SpringBoot
- 그리디
- Spring Boot
- 백준
- AOP
- Thymeleaf
- JPQL
- Today
- Total
목록Spring Boot (54)
개발자되기 프로젝트
1. 등록된 회원들의 이름을 조회 MemberRepository @Query("select m.userName from Member m") List findUserNameList(); Test @Test public void findUserNameList(){ Member member1 = new Member("aaa", 10); Member member2 = new Member("bbb", 20); memberRepository.save(member1); memberRepository.save(member2); List userNameList = memberRepository.findUserNameList(); for (String userName : userNameList) { System.out.p..
1. Query Method의 기능 메소드 이름으로 쿼리 생성 NamedQuery @Query - 리파지토리 메소드에 쿼리 정의 파라미터 바인딩 반환 타입 페이징과 정렬 벌크성 수정 쿼리 @EntityGraph 2. 메소드 이름으로 쿼리 생성 메소드 이름을 분석해서 JPQL 쿼리 실행 이름과 나이를 기준으로 회원을 조회하려면? 먼저 JPA로 짜보자 public List findMemberByUserNameAndAgeGreaterThan(String userName, int age){ return em.createQuery("select m from Member m where m.userName = :userName and m.age > :age") .setParameter("userName", userN..
1. Entity Class Member와 Team은 다대일 연관관계 2. ERD 3. Member class xToOne은 기본적으로 fetch type이 EAGER이다. 항상 LAZY를 적용하자(지연로딩) package study.datajpa.entity; import lombok.*; import javax.persistence.*; @Entity @Getter @Setter @NoArgsConstructor(access = AccessLevel.PROTECTED) @ToString(of = {"id", "userName", "age"}) public class Member { @Id @GeneratedValue @Column(name = "member_id") private Long id; pr..
다 조인시켜서 한방쿼리로 가져오자. 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. DTO를 직접 가져오기 위해 DTO 및 repository생성. @Data public class OrderQueryDto { private Long orderId; private String name; private LocalDateTime orderDate; private OrderStatus orderStatus; private Address address; private List orderItems; public OrderQueryDto(Long orderId, String name, LocalDateTime orderDate, OrderStatus orderStatus, Address address) { this.orderId = orderId; this.name = name; this.o..
1. fetch join fetch join을 적용해서 일대다 조회를 해보자. public List findAllWithItem(){ List resultList = em.createQuery("select o from Order o " + "join fetch o.member m " + "join fetch o.delivery d " + "join fetch o.orderItems oi " + "join fetch oi.item i", Order.class).getResultList(); return resultList; } 현재 db에 order는 2개, orderItem은 4개 가 있다. 일대다 관계이기 때문에 DB입장에서 ORDER,와 ORDER_ITEM을 JOIN하면 ORDER의 DATA가 불어..
컬렉션인 일대다 관계를 조회하고, 최적화하자. 일대다 조회는 DB입장에서 data가 뻥튀기 된다. 예를들어 하나의 주문(orderA)에 item( #1, #2, #3)이 3개라면 data는 1개가 아니라 3개가 된다. orderA - #1, orderA - #2, orderA-#3 1. 엔티티 직접 노출 : V1 get을 통해 member, orderItem, Delivery 프록시를 강제로 초기화 시킨다. @RestController @RequiredArgsConstructor public class OrderApiController { private final OrderRepository orderRepository; @GetMapping("/api/v1/orders") public List orde..
1. DTO 로 변환해서 리턴. @GetMapping("/api/v2/simple-orders") public List odersV2(){ List orders = orderRepository.findAllByString(new OrderSearch()); List result = orders.stream() .map(o -> new SimPleOrderDto(o)) //map은 a를 b로 바꾸는 것. .collect(Collectors.toList()); return result; } @Data private class SimPleOrderDto { private Long orderId; private String name; private LocalDateTime orderDate; private Or..