개발(합니다)/Java&Spring

[spring boot 설정하기-3.2] JPA 설정 및 사용 방법

otrodevym 2021. 4. 6. 00:00
반응형

DB 연결에 최근 떠오르는 JPA를 설정하는 방법을 포스팅합니다.

3.1에 이어서 포스팅을 이어가지만 3.2 JPA 환경 설정내용만 보셔도 됩니다.

spring-data-jpa 관련 정보는 아래 사이트에서 확인할 수 있습니다.
https://docs.spring.io/spring-data/jpa/docs/2.4.x/reference/html/#reference

www.baeldung.com/spring-data-jpa-query


1. 의존성 추가

    // https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-data-jpa
    implementation 'org.springframework.boot:spring-boot-starter-data-jpa'

2. application.yml 설정

jpa를 위한 설정을 합니다.

# API 호출시, SQL 문을 콘솔에 출력
  jpa:
    show-sql: true
    # DDL 정의시 데이터베이스의 고유 기능을 사용
    # ex) 테이블 생성, 삭제 등
    generate-ddl: true
    database: mysql
    database-platform: org.hibernate.dialect.MySQL5InnoDBDialect
    hibernate:
      ddl-auto: update

3. DB에서 스키마 생성

테스트 하기 위한 테이블을 생성합니다.

create table jpa_user (
    num int not null auto_increment,
    name char(50) not null,
    primary key (num)
    );

4. JPA 연동 테스트

패키지 구성은 아래 사진과 같습니다.

기존 설정했던 내용도 패키지별로 모아두었습니다.

4-1. JpaUser 생성

package com.otrodevym.spring.base.common.jpa;

import lombok.Getter;
import lombok.Setter;
import lombok.ToString;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;


@Getter
@Setter
@ToString
@Entity
public class JpaUser {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private int num;

    private String name;
}

4-2. JapUserService 생성

package com.otrodevym.spring.base.common.jpa;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;


@Service
public class JapUserService {

    @Autowired
    private JpaUserRepository jpaUserRepository;


    public JpaUser signup(JpaUser jpaUser) {
        JpaUser jpaUserResult = jpaUserRepository.save(jpaUser);
        return jpaUserResult;
    }
}

4-3. JpaUserContoller 생성

package com.otrodevym.spring.base.common.jpa;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;


@RestController
@RequestMapping("/user")
public class JpaUserContoller {

    @Autowired
    private JapUserService japUserService;

    @PostMapping("/signup")
    public JpaUser signup(@RequestBody JpaUser jpaUser) {
        JpaUser jpaUserResult = japUserService.signup(jpaUser);
        return jpaUserResult;
    }

}

4-4. JpaUserRepository 생성

package com.otrodevym.spring.base.common.jpa;

import org.springframework.data.repository.CrudRepository;


public interface JpaUserRepository extends CrudRepository<JpaUser, Long> {

}

4-5. postman Post 전송

localhost:8080/user/signup

{
    "name" : "otro"
}

4-6. 결과 확인

5. CrudRepository 기본 사용방법

CrudRepository를 상속받아 사용하여 기본적인 CRUD를 제공받아서 사용할 수 있습니다.
https://docs.spring.io/spring-data/commons/docs/current/api/org/springframework/data/repository/CrudRepository.html

Modifier and Type Method and Description
long count() Returns the number of entities available.
void delete(T entity) Deletes a given entity.
void deleteAll() Deletes all entities managed by the repository.
void deleteAll(Iterable<? extends T> entities) Deletes the given entities.
void deleteById(ID id) Deletes the entity with the given id.
boolean existsById(ID id) Returns whether an entity with the given id exists.
Iterable<T> findAll() Returns all instances of the type.
Iterable<T> findAllById(Iterable<ID> ids) Returns all instances of the type T with the given IDs.
Optional<T> findById(ID id) Retrieves an entity by its id.
<S extends T> S save(S entity) Saves a given entity.
<S extends T>Iterable<S> saveAll(Iterable<S> entities) Saves all given entities.

6. JPA 어노테이션 설명

  • @Query : 네이티브 쿼리 사용 가능
  • @Entity: DB의 테이블 설정
  • @Table: DB 테이블의 이름을 명시하며 테이블과 클래스가 같다면 자동 설정
  • @Id: Index primary key를 의미
  • @Column: DB Column을 명시
  • @GeneratedValue: Primary Key의 전략(Strategy)를 설정하며 디폴트 값은 AUTO이다.
    • AUTO : (persistence provider가) 특정 DB에 맞게 자동 선택
    • IDENTITY : DB의 identity 컬럼 참조
      • SEQUENCE : DB의 시퀀스 컬럼 참조
    • TABLE : 유일성이 보장된 데이터베이스 테이블 참조

7. JPQL 대비 예제

키워드 예제 JPQL 정보
Distinct findDistinctByLastnameAndFirstname select distinct …​ where x.lastname = ?1 and x.firstname = ?2
And findByLastnameAndFirstname … where x.lastname = ?1 and x.firstname = ?2
Or findByLastnameOrFirstname … where x.lastname = ?1 or x.firstname = ?2
Is, Equals findByFirstname,findByFirstnameIs,findByFirstnameEquals … where x.firstname = ?1
Between findByStartDateBetween … where x.startDate between ?1 and ?2
LessThan findByAgeLessThan … where x.age < ?1
LessThanEqual findByAgeLessThanEqual … where x.age <= ?1
GreaterThan findByAgeGreaterThan … where x.age > ?1
GreaterThanEqual findByAgeGreaterThanEqual … where x.age >= ?1
After findByStartDateAfter … where x.startDate > ?1
Before findByStartDateBefore … where x.startDate < ?1
IsNull, Null findByAge(Is)Null … where x.age is null
IsNotNull, NotNull findByAge(Is)NotNull … where x.age not null
Like findByFirstnameLike … where x.firstname like ?1
NotLike findByFirstnameNotLike … where x.firstname not like ?1
StartingWith findByFirstnameStartingWith … where x.firstname like ?1 (parameter bound with appended %)
EndingWith findByFirstnameEndingWith … where x.firstname like ?1 (parameter bound with prepended %)
Containing findByFirstnameContaining … where x.firstname like ?1 (parameter bound wrapped in %)
OrderBy findByAgeOrderByLastnameDesc … where x.age = ?1 order by x.lastname desc
Not findByLastnameNot … where x.lastname <> ?1
In findByAgeIn(Collection<Age> ages) … where x.age in ?1
NotIn findByAgeNotIn(Collection<Age> ages) … where x.age not in ?1
True findByActiveTrue() … where x.active = true
False findByActiveFalse() … where x.active = false
IgnoreCase findByFirstnameIgnoreCase … where UPPER(x.firstname) = UPPER(?1)
반응형