Spring Data Jpa와 H2 Database를 사용하여 게시글을 조회, 등록, 수정, 삭제하는 API를 구현하겠습니다. 1.Dependency 설정 pom.xml 2.Properties 설정 application.properties 3.Entity 구현 JPA에서 제공하는 어노테이션 @Entity 클래스와 테이블과 매핑한다고 JPA에게 전달하며, @Entity 어노테이션이 선언된 클래스를 엔티티 클래스라고 합니다. @Table 엔티티 클래스에 매핑할 테이블 정보를 전달하며, 생략 시 클래스명을 테이블명으로 매핑합니다. @Id 엔티티 클래스의 필드를 테이블에 기본 키(PK, Primary key)로 매핑합니다. @GeneratedValue 생성 전략(strategy)에 따라 기본 키를 지정합니다. AUTO(default) - JPA가 자동으로 생성 전략을 결정합니다. IDENTIT - 기본키 생성을 데이터베이스에 위임한다. 예를 들어 MySQL의 경우 AUTO_INCREMENT를 사용하여 기본키를 생성합니다. SEQUENCE - 데이터베이스의 특별한 오브젝트 시퀀스를 사용하여 기본키를 생성합니다. TABLE - 데이터베이스에 키 생성 전용 테이블을 하나 만들고 이를 사용하여 기본키를 생성합니다. @Column 엔티티 클래스의 필드를 컬럼에 매핑하며, 생략 시 필드명을 컬럼에 매핑합니다. @Lob 엔티티 클래스의 필드를 데이터베이스 BLOB, CLOB, TEXT 타입과 맵핑합니다. Lombok에서 제공하는 어노테이션 @NoArgsConstructor 기본 생성자를 자동으로 추가합니다. @Getter 클래스 내 모든 필드의 Getter 메소드를 자동 생성합니다. @Builder 해당 클래스의 빌더 패턴 클래스를 생성합니다. 생성자 상단에 선언 시 생성자에 포함된 필드만 빌더에 포함합니다. Board.java 4.Dto 구현 Entity 클래스를 변경하는 경우 DB Layer에 영향을 주기 때문에, View Layer에서 사용할 Request/Response Dto를 추가하세요. BoardSaveRequestDto.java BoardUpdateRequestDto.java BoardResponseDto.java 5.Repository 구현 Spring Data JPA는 Repository 계층의 반복되는 작업을 피하기 위해 JpaRepository 인터페이스를 제공합니다. JpaRepository 인터페이스에는 자주 사용되는 기본적인 CRUD 메서드가 선언되어 있는데, 개발자는 Repository 클래스를 생성하지 않고 인터페이스를 생성하여 JpaRepository 인터페이스를 상속받으면 JpaRepository에서 선언한 메서드들을 사용 할 수 있게 됩니다. 또한 JpaRepository에서 제공하는 메서드 외에 필요한 쿼리를 수행하기 위한 메서드를 직접 정의할 수도 있습니다. BoardRepository.java 6.Service 구현 BoardService.java 7.Controller 구현 BoardController.java 8.SQL Script src/main/resources에 import.sql 파일이 있으면 서버 실행 시에 해당 스크립트를 자동 실행합니다. import.sql 9.프로젝트 구조 Github Repository - https://github.com/tychejin1218/jpa-sample springboot는 jsp 사용을 권장하지 않는다. H2DB를 사용할 예정이므로 아래 게시물을 참고하여 로컬에 H2DB 설치가 필요함. 2021.08.01 - [개발/database] - [H2 DB] 설치 및 실행 프로젝트 생성 시 선택 한 Dependencies jsp 사용을 위한 jstl과 tomcat-embed-jasper를 pom.xml 에 추가
application.peoperties에 ViewResolver 세팅
src/main/webapp/WEB-INF/jsp 폴더 생성 (spring boot는 jsp를 기본적으로 지원하지 않기 때문에 폴더를 생성해야 한다) 게시판 목록 조회 만들기 1. Board 도메인 만들기
2. Board Controller 만들기 - jsp에 잘 나오는지 테스트용 목록 화면 컨트롤러
3. src/main/webapp/WEB-INF/jsp 폴더 아래 testBoardList.jsp 파일 만들기
4. 브라우저로 확인 (localhost:8080/testBoardList) H2 데이터 베이스, JPA 연동 5. Board.java 엔티티 클래스로 변경
6. board 테이블 생성을 위한 application.properties 수정 (spring.jpa.hibernate.ddl-auto=create : 프로그램 실행 시 ddl을 생성한다. (ex. 테이블..)) (실행시마다 데이터가 삭제되는 걸 방지 하려면 최초 create 로 실행 후 이후에는 update로 변경 해야함.)
7. Repository 인터페이스 생성 - Board 엔티티를 이용한 데이터베이스에 조회/생성/수정/삭제 담당
8. 비즈니스 컴포넌트 만들기 (Class, Interface)
9. BoardController에서 비즈니스 컴포넌트 사용 기존 BoardController 에서 BoardService를 autowired하고 하단에 getBoardList 메소드를 추가
10. 테스트로 만든 testBoardList.jsp를 복사하여 getBoardList.jsp를 만들자 11. 재부팅 시 하이버네이트 로그 확인 (테이블 생성 스크립트 출력)
12. 브라우저로 확인 (localhost:8080/getBoardList) - 실제 테이블에 데이터가 없어서 글이 조회되지 않는다. board 테이블이 조회되는 쿼리가 로그에서 확인 가능 실제 콘솔 표시 화면13. 새글쓰기 컨트롤러, 화면, 서비스 만들기 BoardController.java
insertBoard.jsp
BoardServiceImpl.java
14. 글쓰기 화면/기능 확인 http://localhost:8080/getBoardListhttp://localhost:8080/insertBoardView"등록" 버튼 클릭 시 글이 등록되며, 목록화면으로 redirect 된다. http://localhost:8080/getBoardList15. 글 상세 조회 BoardController.java
BoardServiceImpl.java
getBoard.jsp
15. 상세글 조회 화면/기능 확인 http://localhost:8080/getBoard?seq=316. 글 수정 BoardController.java
BoardServiceImpl.java
17. 글 삭제 처리 BoardController.java
BoardServiceImpl.java
18. 전체 소스 구조 19. 파일별 전체 소스 pom.xml
BoardController.java
Board.java
BoardRepository.java
BoardService.java
BoardServiceImpl.java
application.properties
getBoard.jsp
getBoardList.jsp
insertBoard.jsp
testBoardList.jsp |