인프런/실전! 스프링 데이터 JPA6 끝) [미완] 나머지 기능들 - Specifications(명세),Query By Example,Projections,네이티브 쿼리 복잡도에 비해서 실무에서는 많이 사용되지않는다. [ 다른 대안도 존재하기도 하고 ]왜 실무에서 쓰기에 애매한지를 초점에 맞춘다. Specifications (명세) 도메인 주도 설계(Domain Driven Design)라는 책에는 SPECIFICATION(명세)라는 개념을 소개 스프링 데이터 JPA는 JPA Criteria를 활용해서 이 개념을 사용할 수 있도록 지원 [ JPA Criteria를 사용하면 코드가 읽기 어려워서 실무에서는 안쓴다고 한다. 이런게 있구나로 보면된다.] 술어(predicate)- 참 또는 거짓으로 평가- AND OR 같은 연산자로 조합해서 다양한 검색조건을 쉽게 생성(컴포지트 패턴)- 예) 검색 조건 하나하나- 스프링 데이터 JPA는 org.springframework.d.. 인프런/실전! 스프링 데이터 JPA 2024. 6. 14. 5) 스프링 데이터 JPA 구현체 분석,merge,새로운 엔티티 구별방법 스프링 데이터 JPA 구현체 분석 스프링 데이터 JPA가 제공하는 공통 인터페이스의 구현체org.springframework.data.jpa.repository.support.SimpleJpaRepository@Repository@Transactional( readOnly = true)public class SimpleJpaRepository implements JpaRepositoryImplementation {@Repository 적용: JPA 예외를 스프링이 추상화한 예외로 변환 @Transactional 트랜잭션 적용 JPA의 모든 변경은 트랜잭션 안에서 동작 [ 트랜잭션 필수 ] 스프링 데이터 JPA는 변경(등록, 수정, 삭제) 메서드를 트랜잭션 처리@Transactionalpublic .. 인프런/실전! 스프링 데이터 JPA 2024. 6. 14. 4) WEB 확장기능 - 도메인 클래스 컨버터, 페이징과 정렬 Web 확장 - 도메인 클래스 컨버터 HTTP 파라미터로 넘어온 엔티티의 아이디로 엔티티 객체를 찾아서 바인딩 @RestController@RequiredArgsConstructorpublic class MemberController { private final MemberRepository memberRepository; @GetMapping("/members/{id}") public String findMember(@PathVariable Long id) { return memberRepository.findById(id).get().getUsername(); } @PostConstruct public void init() { memberRep.. 인프런/실전! 스프링 데이터 JPA 2024. 6. 13. 3) 확장 기능 - 사용자 정의 리포지토리 구현, Auditing 사용자 정의 리포지토리 구현스프링 데이터 JPA 리포지토리는 인터페이스만 정의하고 구현체는 스프링이 자동 생성스프링 데이터 JPA가 제공하는 인터페이스를 직접 구현하면 구현해야 하는 기능이 너무 많음 다양한 이유로 인터페이스의 메서드를 직접 구현하고 싶다면?JPA 직접 사용( EntityManager )하고 싶다거나스프링 JDBC Template 사용한다거나MyBatis 사용한다거나데이터베이스 커넥션 직접 사용 등등...Querydsl 사용 과 같은 여러 이유에서 스프링 데이터 JPA가 제공하는 인터페이스를 직접 구현하고 싶다면?public interface MemberRepository extends JpaRepository { List findByUsernameAndAgeGreaterThan(S.. 인프런/실전! 스프링 데이터 JPA 2024. 6. 12. 2) 쿼리 메소드 기능 쿼리 메소드 기능스프링 데이터 JPA가 제공하는 마법 같은 기능 쿼리 메소드 기능 3가지- 메소드 이름으로 쿼리 생성 - 메소드 이름으로 JPA NamedQuery 호출 - @Query 어노테이션을 사용해서 리파지토리 인터페이스에 쿼리 직접 정의 메소드 이름으로 쿼리 생성 이름과 나이를 기준으로 회원을 조회하는 메소드를순수 JPA로 구현하면public List findByUsernameAndAgeGreaterThan(String username, int age) { return em.createQuery("select m from Member m where m.username = :username and m.age > :age ") .setParameter("userna.. 인프런/실전! 스프링 데이터 JPA 2024. 6. 12. 1) 예제 도메인 모델, 공통 인터페이스 기능 소개 멤버에서 팀은 다대일팀에서 멤버스[컬렉션]은 일대다양방향 연관관계 @Entity@Getter @Setter// JPA가 프록시 기술같은걸 사용할때 기본생성자가 필요하다, private로 해두면 JPA가 사용할수없으므로 Protected로 해둔다.// [개발자가 실수로 사용하는것을 막기위해 protected로 제한 ]@NoArgsConstructor(access = AccessLevel.PROTECTED)@ToString(of ={"id","username","age"} ) // id, username, age 필드만 포함하여 toString() 메서드를 생성하라는 것, team이 포함되면 무한참조순환이 되므로 뺴준것public class Member { @Id @GeneratedValue .. 인프런/실전! 스프링 데이터 JPA 2024. 6. 11. 이전 1 다음