JPA(3)
-
스프링부트에서 JPA-MySQL 연동하기 3: 1:N 연관관계 설정
지난 번까지는 각 테이블 간의 연관관계를 하나도 지정해주지 않고 기본적인 작동 방식만 알아보았다. 이번에는 PK-FK로 연관된 테이블의 관계를 엔티티에서 역시 맺어보고자 한다. 이 프로젝트의 테이블들의 상관관계는 다음과 같다. 상품과 관련된 prod 테이블이 있고, 상품을 조회하면 글/이미지 쌍으로 디테일이 있는 prod_detail 테이블이 있다. 두 테이블은 1(prod) : N(prod_detail) 관계이다. prod 테이블의 no 컬럼이 PK이며, prod_detail의 prod_no 컬럼이 prod 테이블을 참조하는 컬럼이다. 상품이 삭제되면 디테일도 삭제되어야 하기 때문에 양방향 관계를 가진다. 이 방향이라는 것은, 양방향/ 단방향이 있다. 테이블 개념에서 볼 때 PK-FK로 연관관계를 맺고..
2020.03.26 -
스프링부트에서 JPA-MySQL 연동하기 2: 레포지토리 설정
목차 1. DAO, Service, Controller 작성 2. REST API를 사용하여 회원가입 기능 구현 이번에는 간단히 CRUD 기능을 사용하기 위해 DAO, Service, Controller를 작성하는 것에 대해 알아보고자 한다. 1. DAO, Service, Controller 작성 MyBatis 환경에서 DAO와 동일한 개념이 레포지토리 인터페이스이다. 여기서 JPA의 특징적인 점은 별도의 구현 클래스를 만들지 않고 인터페이스만 정의함으로써 기능을 사용할 수 있다는 것이다. 여기서 보통 Spring Data 모듈에서 제공하는 CrudRepository를 상속한다. 추가적으로 페이징 처리를 할 경우에는 PagingAndSortingRepository를 사용한다. package com.cod..
2020.03.24 -
스프링부트에서 JPA-MySQL 연동하기 1: 엔티티 설정
목차 1. perspective 설정 2. 새 프로젝트 생성 3. application.properties 작성 4. 엔티티 클래스 매핑 * Git Repository에 업로드 기존에 MyBatis로 DB를 사용했던 것을 JPA로 전환하려고 한다. 작업한 코드는 여기에 업로드하였다. 1. perspective 설정 Spring 선택 2. 새 프로젝트 생성 Spring Starter Project 선택 정보 입력 5가지 의존성 추가 3. application.properties 작성 # DataSource Setting spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.url=jdbc:mysql://127.0.0.1..
2020.03.23