목록BE (354)
오봉이와 함께하는 개발 블로그
네이티브 쿼리 가급적 네이티브 쿼리는 사용하지 않는게 좋기 때문에 정말 어쩔 수 없을 때 사용하자. 최근에 나온 네이티브 쿼리 활용 방법은 스프링 데이터 Projections를 활용하는 방법이다. 스프링 데이터 JPA 기반 네이티브 쿼리 페이징 지원 반환 타입 Object[] Tuple DTO(스프링 데이터 인터페이스 Projections를 지원함) 제약 반환 타입이 적기 때문에 사용하기 어중간하다. Sort 파라미터를 통한 정렬이 정상 동작하지 않을 수 있음(믿지 말고 직접 처리) JPQL처럼 애플리케이션 로딩 시점에 문법 확인 불가 동적 쿼리 불가 JPA 네이티브 SQL 지원 public interface MemberRepository extends JpaRepository { @Query(value..
Projections 엔티티 대신에 DTO를 편리하게 조회할 때 사용한다. public interface UsernameOnly { String getUsername(); } 조회할 엔티티의 필드를 getter 형식으로 지정하면 해당 필드만 선택해서 조회(Projection) public interface MemberRepository ... { List findProjectionsByUsername(String username); } 메서드 이름은 자유, 반환 타입으로 인지 @Test public void projections() throws Exception { //given Team teamA = new Team("teamA"); em.persist(teamA); Member m1 = new Mem..
새로운 엔티티를 구별하는 방법 save() 메소드 새로운 엔티티면 저장(persist) 새로운 엔티티가 아니면 병합(merge) 새로운 엔티티를 판단하는 기본 전략 식별자가 객체일 때 null인지 아닌지 여부로 판단 식별자가 자바 기본 타입일 때 0인지 아닌지 여부로 판단 Persistable 인터페이스를 구현해서 판단 로직 변경 가능 package org.springframework.data.domain; public interface Persistable { ID getId(); boolean isNew(); } JPA 식별자 생성 전략이 @GenerateValue면 save() 호출 시점에 식별자가 없으므로 새로운 엔티티로 인식해서 정상 동작한다. 그런데 JPA 식별자 생성 전략이 @Id만 사용해서..
스프링 데이터 JPA 구현체 분석 스프링 데이터 JPA가 제공하는 공통 인터페이스의 구현체 org.springframework.data.jpa.repository.support.SimpleJpaRepository @Repository @Transactional(readOnly = true) public class SimpleJpaRepository ...{ @Transactional public S save(S entity) { if (entityInformation.isNew(entity)) { em.persist(entity); return entity; } else { return em.merge(entity); } } // ......... } @Repository 적용 : JPA 예외를 스프링이..
Web 확장 - 페이징과 정렬 스프링 데이터가 제공하는 페이징과 정렬 기능을 스프링 MVC에서 편리하게 사용할 수 있다. 페이징과 정렬 예제 @GetMapping("/members") public Page list(Pageable pageable) { Page page = memberRepository.findAll(pageable); return page; } 파라미터로 Pageable을 받을 수 있다. Pageable은 인터페이스다. 실제는 org.springframework.data.domain.PageRequest 객체 생성 { ......................... { "createdDate": "2022-09-14T01:54:54.034161", "lastModifiedDate": "2..