스프링부트(4)
-
스프링부트에서 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 -
스프링부트 간단히 시작하기
스프링을 보다 쉽게 사용할 수 있게 개발된 것이 스프링부트이다. 라이브러리 관리, 버전 관리 등을 보다 더 용이하게 해준다. 부트를 사용하기 위해서 먼저 환경설정이 필요하다. 가장 기본적으로는 1. JAVA 2. Eclipse 두 가지가 깔려 있어야 한다. 나는 자바 1.8버전, 이클립스는 2019년 9월 버전이 깔려있는 상태이다. 먼저 이클립스 도구창에서 마켓플레이스에 들어간다. 'sts'를 검색창에 입력하여 Spring Tools 3을 설치한다. 나는 이미 깔려있는 상태이다. 설치를 마치고 다시 도구창에서 Perspective에서 Spring을 선택한다. 위와 같이 이클립스 화면이 달라진 것을 확인할 수 있다. 뷰 창들은 쓰다가 필요에 맞게 변경하면 될 것 같다. 이제 프로젝트를 생성하고자 한다. S..
2020.03.04