jpa

    JPA :: 벌크성 수정 쿼리

    JPA :: 벌크성 수정 쿼리

    벌크 연산 여러 건의 데이터를 한 번에 수정하거나 삭제 조건에 맞는 객체를 다 가지고 와서 수정할 필요 없이 DB 쿼리로 해결하는 것. JPA Bulk 예제 코드 : 파라미터로 받은 나이보다 많은 회원들의 나이를 +1 시킨다. public int bulkAgePlus(int age) { return em.createQuery( "update Member m set m.age = m.age + 1" + " where m.age >= :age") .setParameter("age", age) .executeUpdate(); } 테스트 코드 @Test public void bulkUpdate() { //given memberJpaRepository.save(new Member("member1", 10)); m..

    JPA :: 페이징과 정렬

    JPA :: 페이징과 정렬

    기존 JPA 페이징과 정렬 public List findByPage(int age, int offset, int limit) { return em.createQuery("select m from Member m where m.age = :age order by m.username desc") .setParameter("age", age) .setFirstResult(offset) .setMaxResults(limit) .getResultList(); } public long totalCount(int age) { return em.createQuery("select count(m) from Member m where m.age = :age", Long.class) .setParameter("age", a..

    JPA :: Query Method 기능

    JPA :: Query Method 기능

    스프링 데이터 JPA 가 제공하는 마법같은 기능이 있다. 바로 “쿼리 메소드” 기능인데, 결론부터 말하면 3가지 기능이 있다. 메소드 이름으로 쿼리 생성 메소드 이름으로 JPA NamedQuery 호출 @Query 어노테이션을 사용해서 Repository interface 에 쿼리 직접 정의 Method 이름으로 Query 생성 메소드 이름을 분석해서 JPQL 쿼리 실행 예) 이름과 나이를 기준으로 회원을 조회하려면 ? // 순수 JPA Repository public List findByUsernameAndAgeGreaterThan(String username, int age) { return em.createQuery("select m from Member m where m.username = :us..

    Spring Boot :: Spring Data 패키지 구조

    Spring Boot :: Spring Data 패키지 구조

    Spring Data JPA 를 활용해서 인터페이스를 사용할 때 JpaRepository 를 상속받아서 사용한다. 이 JpaRepository 안에 들어가면 또 다른 Repository 를 상속받고 또 상속받고 ,, 이 구조에 대해서 기록해두고자 한다. 인터페이스 살펴보기 먼저 MemberRepository 라는 레포지토리를 만들어보았다. public interface MemberRepository extends JpaRepository { } 여기서 JpaRepository 안에 들어가보자. 패키지 위치는 org.springframework.data.jpa.repository 이다. JpaRepository 는 PagingAndSortingRepository 를 상속받고 있고, PagingAndSort..

    Spring Boot :: Spring Data JPA

    Spring Boot :: Spring Data JPA

    인터페이스만 정의해도 CRUD 기능을 사용할 수 있다 ? 테스트 코드를 통해서 CRUD 기능이 동작하는지 간단하게 테스트해보자. 테스트 순서 Entity 생성 순수 JPA Repository 생성 후 테스트 Data JPA Repository 생성 후 테스트 Entity 생성 먼저 Member Entity 를 만들자. @Entity @Getter @Setter @NoArgsConstructor(access = AccessLevel.PROTECTED) @ToString(of = {"id", "username"}) public class Member { @Id @GeneratedValue @Column(name = "member_id") private Long id; private String usernam..

    JPA :: Auditing 엔티티 공통 정보 추가하기

    JPA :: Auditing 엔티티 공통 정보 추가하기

    Auditing JPA 에서 도메인을 RDB 테이블에 매핑할 때, 도메인들이 공통으로 가지고 있는 필드들 존재 생성일자, 수정일자, 생성자, 수정자 등 JPA 에서 Audit 기능 제공 Spring Data JPA 에서 시간 값을 자동으로 넣어줌 Auditing 예시 코드 build.gradle 에 의존성 추가 dependency { implementation 'org.springframework.boot:spring-boot-starter-data-jpa' } 스프링 부트에서 gradle 로 의존성을 관리한다면 spring-boot-starter-data-jpa 만 추가해주면 된다. BaseTimeEntity.java @Getter @MappedSuperclass @EntityListeners(Audi..

    Spring Boot :: JPA란?

    Spring Boot :: JPA란?

    이동욱님의 스프링 부트와 AWS 로 혼자 구현하는 웹 서비스 와 인프런 김영한님의 자바 ORM 표준 JPA 프로그래밍 기본편 을 보다가 JPA 에 대해 이해하기 쉽게 설명된 부분이 있어 인용해서 적어보았다. 웹 서비스를 개발하면서 피할 수 없는 문제는 DB 를 다루는 일이다. 특히 백엔드 개발자를 희망하고 공부하면서 느끼는 점은 DB를 다룰 일이 생각보다 많다는 것. 당장 백엔드 프레임워크를 이용해서 어플리케이션 개발에 몰두하기에도 시간이 부족한데, DB는 또 언제 공부하는지.. 어쨌든 RDB 를 이용하는 프로젝트에서 어떻게 객체지향 프로그래밍을 할 수 있을까 에 대한 해답으로 JPA 라는 자바 표준 ORM (Object Relational Mapping) 기술을 만나게 된다. 참고로 MyBatis, i..