SpringBoot JPA 예제(결합 인덱스)

 

Springboot JPA 2탄입니다. Springboot나 Spring이나 JPA 적용하는 법은 같아요. 이번에는 PK가 하나가 아닌 2개인 경우의 테이블을 JPA Repository로 구성하는 법을 알아봅니다.

1. 준비

이 포스팅은 SpringBoot JPA 예제에서 파생되었습니다. JPA에 대해 기본적인 사용 방법을 설명해 놓았습니다.

또한 이번 포스팅에서 사용하는 DB는 MariaDB입니다.

2. 예제

실제 소스 코드를 하나씩 구성해 보면서 알아가 봅시다.

2.1. DB Table

CREATE TABLE `member` (
	`id` INT(10) NULL,
	`name` VARCHAR(50) NULL,
	`age` INT NULL,
	PRIMARY KEY (`id`, `name`)
)
COLLATE='utf8_general_ci'
ENGINE=InnoDB;

MariaDB에 위와 같은 member 테이블을 구축합니다. 이 테이블은 id, name, age를 컬럼으로 가지고 있으며 id와 name을 묶어서 결합 인덱스(PK)를 가집니다. 이제 이 테이블을 자바 JPA Entity로 바꿔봅시다.

2.2. EntityPK

먼저 결합 인덱스를 표현할 클래스를 하나 만듭니다. 클래스 이름은 MemberPK입니다. 소스 코드는 아래와 같습니다.

package jpa2;

import java.io.Serializable;
import javax.persistence.Column;
import javax.persistence.Embeddable;

@Embeddable
public class MemberPK implements Serializable {

	private static final long serialVersionUID = 1L;

	@Column(name="id", nullable=false)
	private Long id;

	@Column(name="name", nullable=false)
	private String name;

	public MemberPK(){}

	public MemberPK(long id, String name) {
		super();
		this.id = id;
		this.name = name;
	}
}

여기서 @Embeddable 어노테이션을 정의해야 합니다. 그리고 내부 멤버 변수로는 결합할 컬럼들을 넣어줍니다. 그리고 "기본 생성자"는 꼭 넣어주세요.

2.3. Entity

그리고 MemberPK를 가진 Member Entity 클래스를 만듭니다. 소스 코드는 아래와 같습니다.

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

package jpa2;

import javax.persistence.Column;
import javax.persistence.EmbeddedId;
import javax.persistence.Entity;

@Entity
public class Member {

	@EmbeddedId
	private MemberPK pk;

	@Column
	private int age;

	public Member() {}

	public Member(MemberPK pk, int age) {
		this.pk = pk;
		this.age = age;
	}

	public MemberPK getPk() {
		return pk;
	}

	public void setPk(MemberPK pk) {
		this.pk = pk;
	}

	public int getAge() {
		return age;
	}

	public void setAge(int age) {
		this.age = age;
	}
}

여기서 결합 인덱스와 age 컬럼을 가지는 Member Entity를 만들었습니다. 하지만 별도로 id, name 컬럼을 더 넣으면 컬럼이 반복되었다는 오류가 나오니 넣지 않습니다. 결합 인덱스를 나타내기 위해 일반 @Id 어노테이션이 아닌 @EmbeddedId 어노테이션을 선언합니다.

2.4. Repository

마지막으로 Member Repository 인터페이스를 만듭니다. 소스 코드는 아래와 같습니다.

package jpa2;

import org.springframework.data.repository.CrudRepository;

public interface MemberRepository extends CrudRepository<Member, MemberPK> {
}

CrudRepository를 상속 받았지만 JpaRepository를 상속 받아도 됩니다. 두 Repository의 차이점은 JpaRepository가 CrudRepository 및 PagingAndSortingRepository를 포함하고 있습니다. 따라서 일반적인 CRUD 기능만 사용한다면 CrudRepository를 상속받고 그 외 기능이 필요하면 JpaRepository를 상속 받으세요.

한번 더 정리하면 아래처럼 되어 있습니다.

public interface JpaRepository<T, ID extends Serializable> extends PagingAndSortingRepository<T, ID>
public interface PagingAndSortingRepository<T, ID extends Serializable> extends CrudRepository<T, ID>
public interface CrudRepository<T, ID extends Serializable> extends Repository<T, ID>
public interface Repository<T, ID extends Serializable>

2.5. 실행

스프링 부트 어플리케이션이니 실행시키기 위해 아래와 같은 소스 코드를 짰습니다.

package jpa2;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.CommandLineRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class Jpa2Application implements CommandLineRunner {

	@Autowired
	MemberRepository memberRepository;

	public static void main(String[] args) {
		SpringApplication.run(Jpa2Application.class, args);
	}

	@Override
	public void run(String... args) throws Exception {
		memberRepository.save(new Member(new MemberPK(1, "Jung"), 25));
	}
}

위 소스 코드는 결합 인덱스키를 가진 Member 테이블에 새로운 Row를 삽입하는 예제입니다. 위 프로그램을 실행 시키고 DB 데이터를 확인해 보면 예쁘게 들어가 있는 것을 확인 할 수 있습니다.

[출처] https://jdm.kr/blog/140

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
284 Demonstrates CellEditors : Table « SWT JFace Eclipse « Java file 졸리운_곰 2019.06.16 38
283 Demonstrates TableViewers : Table « SWT JFace Eclipse « Java file 졸리운_곰 2019.06.16 60
282 Java and JMX - Building Manageable Systems secret 졸리운_곰 2019.05.26 0
281 Single_Sourcing_RAP_RCP_en.pdf file 졸리운_곰 2019.05.15 27
280 Rich client platform 설명 및 배우기 참고 졸리운_곰 2019.05.15 89
279 Rich Ajax Platform, Part 1: 소개 file 졸리운_곰 2019.05.15 127
278 또 하나의 크로스 플랫폼: Eclipse RAP file 졸리운_곰 2019.05.15 143
277 Eclipse 4 RCP 튜토리얼(완료) file 졸리운_곰 2019.05.14 682
276 [JPA] 쿼리메서드 : 쿼리 연습 조회(findBy..) , 페이징처리 졸리운_곰 2019.03.24 1614
275 스프링 데이터 JPA 레퍼런스 번역 file 졸리운_곰 2019.03.24 1013
274 JPA 개념, class05 JPA 환경설정 졸리운_곰 2019.03.24 53
273 [자바코드] 고유값인 UUID, GUID 생성하기 졸리운_곰 2019.02.27 248
272 [JPA] 복합키 졸리운_곰 2019.02.26 40
271 Spring Batch Multithreading Example file 졸리운_곰 2019.01.31 77
270 Spring batch를 Parallel로 돌려보자 졸리운_곰 2019.01.31 88
269 [GC] 강제로 GC시키기Java 메모리 full 발생시 강제로 GC 시키기 졸리운_곰 2019.01.22 224
268 Java Map 반복(Iteration)시키는 3가지 방법 졸리운_곰 2019.01.01 65
267 jpa muli row select result is same row repeat Java 자바 Jpa에서 멀티 로우 반환시 같은값이 반복 file 졸리운_곰 2019.01.01 153
266 [자바] 리스트를 순회하는 방법 졸리운_곰 2018.12.31 67
265 SpringBoot JPA 예제 졸리운_곰 2018.12.31 55
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED