기본 콘텐츠로 건너뛰기

[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문이 먼저 동작한다.

끝~!!





댓글

이 블로그의 인기 게시물

[스프링부트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 오른쪽 클릭 후...

[Spring] 웹 개발에 필요한 기본 정보들

이번 시간에는 웹 어플리케이션 개발에 필요한 기본 정보를 알아보려한다. MVC 패턴과 이 내용들을 잘 다룰줄 안다면 기본적인 웹 동작은 구현할 수 있을 것이다. 웹 애플리케이션의 종류 화면으로 응답하는 웹 애플리케이션 웹 페이지 형태로 클라이언트에 응답한다. 데이터로 응답하는 웹 애플리케이션 사용자 인터페이스와 데이터를 분리해서 취급하는 애플리케이션은 JSON or Xml을 사용해 데이터 형태로 클라인언트에 응답한다. 애플리케이션 설정 서블릿 컨테이너 설정 스프링 MVC를 이용해 웹 애플리케이션을 할때 ContextLoaderListener, DispatcherServlet, CharacterEncodingFilter를 서블릿 컨테이너에 등록해야 한다. 애플리케이션 컨텍스트 설정 MessageSource와 PropertySourcePlaceholderConfigurer의 빈 정의도 필요하다. 프런트 컨트롤러 설정 자바 기반설정은 @EnableWebMvc를 추가하면 된다. XML에선 <mvc:annotation-driven>요소룰 추하가면 된다. @Controller 구현 컨트롤러에서 구현하는 처리 내용 선언형 처리 : 메서드 시그니처를 참조해 프런트 컨트롤러가 하는 일 프로그래밍형 처리 : 컨트롤러 클래스의 메서드 안에 하는 일 분류 처리내용 선언형 요청매핑 요청 데이터 취득 입력값 검사 수행 프로그래밍형 입력값 검사 결과 확인 비즈니스 로직 호출 이동 대상 확인 및 데이터 연계 이동 대상 지정 컨트롤러 클래스 작성 @Controller public class WelcomController {   } POJO 클래스에 @Controller를 지정하면 다음 효과를 얻을 수 있다. 컴포넌트 스캔 기능을 사용해 DI 컨테이너에 빈으로 등록할 수 있다. 요청을 처리하는 메...

[자바 웹 프로그래밍]1장 첫번째 양파껍질 벗기기

자바 웹 프로그래밍 Next Step 책을 가지고 스터디를 시작했다. 1장은 학습 방향과 학습법에 관한 얘기인데, 나에게 와 닿은 부분을 남겨본다. 웹 개발자 공부 순서  웹을 처음 접했을 때 어디서부터 어느것 부터 공부해야하고 어떤 책을 봐야할지 매우 막막했던 기억이 있다. 본 책에서는 HTML --> CSS --> 자바스크립트 --> 자바 --> 자바웹프로그래밍 --> DB  이 순서로 학습 방향을 제시하고 있다. 백앤드 개발자로 가고 싶어 Spring 프로젝트를 몇차례 진행한 결론은 자바스크립트의 흐름은 어느정도 알고 있는게 도움이 된다는 결론이다.  다음으로 소프트웨어 학습하는 좋은 방법 몇가지가 나오는데, 그 중 내가 최근에 똑같이 느꼈던 것이 있어 적어본다. '일단 무엇인가 만들어보는 경험을 한 후 이론적인 개념을 학습하고, 다시 다음 단계 경험을 하고 이론적인 개념을 학습하는 과정을 반복하는 것이라 생각한다' 라는 구절이 나오는데, 최근 몇차례 Spring 프로젝트를 하면서, 이론에 대한 대략적인것을 기반으로 수많은 삽질과 성취를 이루고 난 다음, 삽질했던 부분을 책이나 인터넷 자료를 봤을때 부족했던 부분이 '아 이건 이렇게 쓰는거구나' 라는 것이 확실히 느낄 수 있었다. 전에는 무조건 '이론먼저 완벽하게 하고 프로젝트 하자!' 식이었는데 이는 경험상 별로 효과를 보지 못한것 같다(이론 금방 까먹는다.. 왜 써야 되는지 못느껴서). 책을 통한 학습  다음 몇가지 책을 추천했는데, 내가 읽은것과 앞으로 읽어봐야 할것을 나열하겠다. 1. 열혈강의 자바 웹 개발 워크북 - 엄진영  이 책 나에게 웹의 세계로 인도를 해주셧던 엄진영 강사님 책이다. 웹이 어떻게 나왔는지 부터 스트링 사용까지 차례대로 차근차근 따라할 수 있게 아주 잘 설명되고 좋은 소스코드를 제공하고 있다. 웹 처음이라면 반드시 볼것을 추천한다. 2. SQL 첫걸음 3. 코딩을 지탱하는 기술...