기본 콘텐츠로 건너뛰기

[SpringBoot] Spring Data JPA를 알아보자 [2탄 엔티티를 다루기]

이번 시간에는 엔티티 클래스 설계서 부터 테스트까지 진행해 보도록 하겠다.

1. 엔티티 클래스 설계
  - JPA는 자동으로 테이블을 생성하는 기능을 가질 수 있다. 다음 2가지 방법이 있다.
    1) SQL을 이용해 테이블을 먼저 생성하고 엔티티 클래스를 만드는 방법
    2) JPA를 이용해 클래스만 설계하고 자동으로 테이블을 생성하는 방법
  - 이중에서 2)번 방법을 알아보자.
  - JPA 엔티티 클래스를 생성하는 작업은 다음 과정을 거친다
    1) 클래스 설계
    2) 각종 애너테이션을 이용해 제약 조건 추가 설정
    3) 엔티티 간 연관관계 설정

1.1 엔티티 클래스 설계
  package com.example.sutdy.domain;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;

import java.sql.Timestamp;

@Getter
@Setter
@ToString
public class Board {
    private Long bno;
    private String title;
    private String writer;
    private String content;
    private Timestamp regdate;
    private Timestamp updatedate;
}

  - 위와 같이 일반적인 방법으로 클래스를 만들어 봤다. 다음 JPA 어노테이션에 관해 알아보고 붙여보자

1.1.2 JPA 어노테이션
  - @Id : 각 엔티티를 구별할수 있도록 식별 ID부과.(일종의 primary key로 보면된다). 모든 엔티티에 반드시 지정하자.
  - @Column : 인스턴스 변수가 컬럼이 되기 원한다면 지정해주자. name, nullable등 다양한 속성이 있다.
  - @Table : 클래스가 테이블이 되기 때문에 클래스 선언부에 작성해 주자. 여러 속성이 있다.
                    @Table이 지정되지 않으면 클래스 이름과 동일한 이름의 테이블이 생성된다.
  - 먼저 클래스 선언부에 반드시 @Entity가 설정되야 한다. 이는 해당 클래스가 엔티티임을 명시한다.
  - @Id는 주로 @GeneratedValue라는 어노테이션과 같이 이용해 식별키를 어떤 전략으로 생성할지 명시한다.
  - 그럼 위클래스에 어노테이션을 붙여보자.

@Getter
@Setter
@ToString
@Entity
@Table(name="tbl_boards")
public class Board {
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long bno;
    private String title;
    private String writer;
    private String content;
    
    @CreationTimestamp
    private Timestamp regdate;
    @UpdateTimestamp
    private Timestamp updatedate;
}

  - 애노테이션은 바로 밑에 한줄에만 적용된다. 그러니까 title부터는 위 에노테이션은 적용안된다.
  - @GeneratedValue의 strategy 속성을 알아보자
    1) AUTO : 특정 데이터베이스에 맞게 자동으로 생성되는 방식
    2)IDENTITY : 기본키 생성 방식 자체를 데이터베이스에 위임. 주로 MySql에서 주로 사용.
    3) SEQUENCE : 데이터베이스의 시퀀스를 이용해 식별키로 생성(오라클 사용)

1.1.3 application.properties에 JAP 설정
spring.jpa.hibernate.ddl-auto=create
spring.jpa.generate-ddl=false
spring.jpa.show-sql=true
spring.jpa.database=mysql
logging.level.org.hibernate=info
  - 위에 줄을 추가해 주자
  - spring.jpa.hibernate.ddl-auto 에는 다양한 옵션을 줄 수 있다. 여기선 테이블 삭제 후 다시 생성하는 방식인 create를 사용했다. 

2. JPA 처리를 담당하는 Repositoy를 설계하자.
  - 과거엔 DAO라는 것이 잇듯, JPA를 이용하는 경우 Repository용어로 인터페이스를 사용한다.
  - Spring Data JPA는 다음과 같은 인터페이스 구조를 사용한다.
    Repository<T,ID> <-- CrudRepository<T,ID>  <--- PagingAndSortingRepository<T, iD> <--JpaRepository<T,ID>
  - T에는 클래스가 오고 ID는 @ID로 설정한 변수의 타입이 온다.
  - 대부분 CrudRepository를 이용한다.

2.1 Repository 인터페이스 설계
  public interface BoardRepository extends CrudRepository<Board,Long> {
    
}
  - 위와 같이 아무것도 작성 안해도 기본적인 메서드를 제공한다.

3. 엔티티 테스트
3.1 등록 작업 테스트
  - Repositroy에서 save()메서드를 호출하면 앤티티 매니저는 영속 컨텍스트를 먼저 확인한다.
  - 영속 컨텍스트에 동일한 엔티티가 없다면 이를 영속컨텍스트에 저장하고, 데이터베이스에 추가한다.
  - 만약 있다면, 보관된 엔티티를 수정하고 데이터베이스를 갱신한다.
  - /src/test/java/패키지 밑에 "BoardRepositoryTest" 클래스 파일을 만들자
package com.example.sutdy;

import com.example.sutdy.domain.Board;
import com.example.sutdy.persistence.BoardRepository;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;

@RunWith(SpringRunner.class)
@SpringBootTest
public class BoardRepositoryTest {
    // 자동주입
    @Autowired
    private BoardRepository boardRepository;

    @Test
    public void testInsert() {
        Board board = new Board();
        board.setTitle("제목입니다.");
        board.setContent("내용이네요.");
        board.setWriter("Mr.oh");

        boardRepository.save(board);
    }
}

  - 위와 같이 작성하고 테스트를 진행하면, SQL문이 처리 되는 것을 볼 수 있다.
  - 처음 넣는 것이라 insert가 실행될 것이다.

3.2 조회작업 테스트
  - 조회는 findById() 함수를 이용한다.
    @Test
    public void testRead() {
        boardRepository.findById(1L).ifPresent((board)->{
            System.out.println(board);
        });
    }
  - 조회 작업은 내부적으로 1차 캐시라는 존재가 등장한다.
  - 외부에서 조회 시 1차 캐시 안에 엔티티가 있는지 보고 없는 경우 SQL문을 통해 가져온다.

3.3 수정작업 테스트
  - 수정은 save()를 호출한다.

JPA는 스스로 엔티티 객체들을 메모리상에 관리하고, 필요한 경우 데이터 베이스에 작업을 한다. 따라서 수정/삭제 작업은 엔티티 객체가 우선 메모리상에 존재하고 있어야 한다. 이를 위해 select문이 먼저 동작한다.

끝~!!





댓글

이 블로그의 인기 게시물

[고량주] 라오왕 연태고량주 플러스

나에게 처음 고량주란 이런것이다 라는걸 알려준 녀석이다. 부모님이 중국집을 하다 보니 가끔 초록색병 고량주를 먹었을때  역한 공업용 알콜 맛에 고량주는 나랑 안맞는다 생각했다가 우연히 양고기에 이녀석을 접한 뒤로 고량주의 맛을 알아버렸다... 제품명 : 라오왕 연태고량주플러스 제품유형 : 일반증류주 도수 : 34.2% 가격 : 9000원(홈플러스 익스프레스 기준) 재구매 의사 : 있다 시음평 : 역시 고량주 특유의 향인데, 열대과일 향도나고, 배향, 살짝 달달한 향이 난다.            목넘김은 34.2%에도 불구하고 그리 힘들지 않았다(주당이 된걸수도..)             중국요리나 양꼬치집에서 맛있는 술이 땡긴다면 강력추천한다.

윈도우 트랙패드로 데트스탑화면 전환

코딩 작업용으로 맥북 트랙패드 사용하다 윈도우에서 마우스 없이 트랙패드로만 사용하려니 이것저것 만지다가 새로운 기능을 발견했다. 1. 새로운 데스크 탑을 만드는 2가지 방법   1) 바탕화면에서 'ctrl' + '윈도우' + 'd'      - 세버튼을 동시에 누르면 새로운 데스크톱 화면이 생성된다.      2) 트랙패드에서 손가락 세개를 사용해 위 방향으로 스크롤      - 위와 같은 화면이 나오는데 우측 하단에 '새 데스크톱'을 클릭하면 추가가 된다. 2. 트랙패드로 데스크톱 화면을 이동하는 2가지 방법   1) 'ctrl' + '윈도우' + 방향버튼(<-(좌) , ->(우))     - 위 버튼을 누르게 되면 데스크톱 화면이 전환이 된다.   2) 트랙패드에서 손가락 네개를 이용해 좌우로 이동     - 위와 같이 데스크톱 화면이 전환이 된다.   3) 세손가락으로 화면 전환은 안될까??     - 곰손인 내가 아기자기한 씽크패드13 같은 트랙패드가 작은 것에서 손가락 4개로 화면전환은 불편함이 있다.😥     - 다음과 같은 설정 방법으로 데스크톱 화면을 전환 할 수 있다.       1>'윈도우키' --> '설정'  --> '장치' --> '트랙패드' --> '세손가락제스처'     - 손가락 제스처 콤보박스를  '바탕화면 전환 및 바탕화면 표시' 로 바꿔주면 손가락 세개로 화면 이동이 가능하다. 마우스를 사용하게 되면 집중력이 떨어진다는 속설(??)이 있어서 최근 마우스를 사용하려 하지 않으려고 한다. 윈도우에서도 이런 꿀팁을 발견하게 되어 개발에 한층 더 집중 할...

[스프링부트2.0 낚시게시판] 01. 프로젝트 생성 및 환경을 세팅해 보자

첫번째. 이클립스에서 프로젝트를 생성해 보자. 빠밤! 1. 이클립스 실행하고 프로젝트 생성하기  - 이클립스 실행 후 File -> New -> Spring Starter Project클릭 ( 부트는 Spring Starter Project로!! )        해당 프로젝트 설정을 본인의 입맛에 맞게? 해주자. 처음엔 저와 똑같이 하는게 삽질(?)의 노고를 덜 수 있으니 저 같은 초보 개발자 분들이나 이제 막 공부를 시작 하셧다면 위와 가이 설정 하는걸 추천.  - New Spring Starter Project Dependencies    - Spring Boot Version : 2.0.2    - Core : DevTools, Security, Lombok 클릭    - Web : web  클릭    - SQL : JPA, H2 클릭    - template Engines : Mstache   --> 타임리프(요즘 회사에서 많이 쓴다고해서)   - 그다음 다음 -> Finish 클릭하게 되면 Maven에 관한 프로젝트가 생성된다.   처음엔 메이븐 디펜던시부분을 받느라 시간이 걸릴수 있다. 프로젝트 구조는 스프링과 별반 차이가 없어 보인다 프로젝트 구조 관련해선 조만간 포스팅 해봐야 겠다. (요즘 책 읽을 시간도 없어서...😂) 두번째. 실행을 해보자.  스프링 부트2.0의 특징은 자체적으로 톰켓이 내장 되어 있어 따로 톰켓을 설정하는 부분이 없어서 아주 매우 편안하게 되었다.    - 실행은 src/main/java 밑에 com.fishing.board 패키지 밑에 FishBoardApplication.java 오른쪽 클릭 후...