Spring Data JPA 연관관계 매핑하는 방법

오늘은 JPA를 사용하는 이유와 Spring Data JPA에서 연관관계 매핑하는 방법에 대해서 알아보겠습니다.

 

JPA란?

  • JPA는 Java Persistance API의 약자로, 자바 진영의 ORM 기술 표준입니다.
     
ORM이란?
  • ORM은 Object-Relational Mapping의 약자로, 객체와 관계형 DB를 매핑하는 기술 입니다.

 

JPA를 사용하는 이유?

  • 생산성
    자바 객체를 사용하여, DB 스키마를 생성 및 SQL 처리를 할 수 있습니다.

     
  • 유지보수 
    기존에는 DB에 필드를 추가할때, DB뿐만 아니라 관련 코드까지 모두 수정해야 하는데, JPA를 사용하면 엔티티 객체에 멤버변수만 추가해주면 된다. 또한, 기본적인 CRUD의 경우 JPA에서 기본적으로 제공해준다.

     
  • 성능
    어플리케이션과 데이터베이스 사이에서 성능 최적화 기능을 제공합니다. 예를들어, 같은 객체를 데이터베이스에서 조회한다고 했을 경우, JPA는 이를 한번만 데이터베이스에 쿼리하고 두번 째는 조회한 객체를 재사용합니다. 

     
  • 데이터베이스 벤더에 대한 독립성
    관계형 DB의 경우 벤더마다 사용법이 조금씩 차이가 있습니다. (예를들어, Mysql의 경우 기본키 자동증가의 경우 auto를 사용. 오라클에서는 Sequence를 사용합니다.) JPA는 어플리케이션과 데이터베이스 사이에 추상화된 데이터 접근 계층을 제공하여 특정 데이터베이스에 종속적이지 않도록 해줍니다.
 
Spring Data JPA에서 연관관계 매핑 방법
  • JPA 엔티티 연관관계시 고려사항
    단방향 : 엔티티가 한쪽 방향으로만 참조가 가능하다.
    양방향 : 엔티티가 양방향에서 서로 참조가 가능하다.
    연관관계 주인 : 연관관계의 주인은 외래키를 관리하고, mappedBy속성을 사용하지 않습니다. (아래 예제코드로 확인)
     
  • JPA 엔티티 연관관계의 종류
    일대일(@OneToOne)
    다대일(@ManyToOne)
    일대다(@OneToMany)
    다대다(@ManyToMany)

Sample code
선생님과 회원의 1:1 개인과외를 JPA 연관관계로 매핑했을 경우를 코드로 표현해보겠습니다.

 

@Entity

@Table(name = "member")

public class Member

{

@Id

@Column(name = "member_id")

private String id;

 

@Column(name = "member_name")

 

private String memberName;
 

@OneToOne //일대일(멤버와 티처는 1:1 관계)

@JoinColumn(name = "teacher_id")  //조인컬럼은 외래키를 매핑할때 사용 (연관관계주인)

 

private Teacher teacher;

(getter, setter 생략)

}

 

@Entity

@Table(name = "teacher")

public class Teacher

{

@Id

@GeneratedValue(strategy = GenerationType.AUTO)

@Column(name = "teacher_id")

private Long id;

 

@OneToOne(mappedBy="teacher")  // Member 객체와 양방향 관계를 만들기위해 추가합니다. 연관관계의 주인이 아님을 mappedBy로 나타냅니다.

 

private Member member;
 

(getter, setter 생략)

}

 

Sample code2
회원과 팀의 다대일 관계를 JPA 연관관계로 매핑했을 경우를 코드로 표현해보겠습니다. (하나의 팀은 다수의 회원을 가질 수 있습니다.)
 

@Entity

@Table(name = "member")

public class Member

{

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

@Id

@Column(name = "member_id")

private String id;

 

@Column(name = "member_name")

 

private String memberName;
 

@ManyToOne   //다대일(회원과 팀은 N:1 관계)

@JoinColumn(name = "team_id")  //조인컬럼은 외래키를 매핑할때 사용 (연관관계주인)

private Team team //연관관계 주인 필드


(getter, setter 생략)

 

}

 

@Entity

@Table(name = "team")

public class Team 

{

@Id

@GeneratedValue(strategy = GenerationType.AUTO)

@Column(name = "team_id")

private Long id;

 

@Column(name = "name", unique=true)

private String name;

 

 

@OneToMany(mappedBy = "team" // Member 객체와 양방향 관계를 만들기위해 추가한다. (대상테이블)

 

private List<Member> members = new ArrayList<Member>();

 

(getter, setter 생략)

}

 

모두 즐거운 코딩 하세요~

 



출처: http://ithub.tistory.com/23 [Fall in IT.]

 

 

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
224 JPA 다대다 관계 모델 @OneToMany로 구현하여 Column 추가하기(@IdClass 사용) file 졸리운_곰 2018.05.18 94
» Spring Data JPA 연관관계 매핑하는 방법 졸리운_곰 2018.05.18 21
222 공유된 FK(Foreign Key) JPA 연관 관계 매핑 하기 file 졸리운_곰 2018.05.18 676
221 JPA - 05. 연관관계 매핑 기초 졸리운_곰 2018.05.18 31
220 SpringBoot JPA 예제(1:N, 양방향) 졸리운_곰 2018.05.18 28
219 SpringBoot JPA 예제(@OneToMany, 단방향) 졸리운_곰 2018.05.18 27
218 JPA / Hibernate One to Many Mapping Example with Spring Boot file 졸리운_곰 2018.05.18 88
217 The best way to map a @OneToMany relationship with JPA and Hibernate file 졸리운_곰 2018.05.18 177
216 (JPA) Embedded Type file 졸리운_곰 2018.05.18 33
215 스프링 데이터 JPA 레퍼런스 번역 file 졸리운_곰 2018.05.14 341
214 UML: 클래스 다이어그램과 소스코드 매핑 file 졸리운_곰 2018.04.30 170
213 lombok에 대해서 알아보자 file 졸리운_곰 2018.04.24 59
212 lombok을 잘 써보자! (2) 졸리운_곰 2018.04.24 151
211 lombok을 잘 써보자! (1) 졸리운_곰 2018.04.24 77
210 Maven 기초 사용법 졸리운_곰 2018.04.15 103
209 [JAVA] Java 와 Mysql 연동 및 DB 사용 졸리운_곰 2018.02.14 88
208 json을 파싱해보자 졸리운_곰 2018.02.12 58
207 [JAVA] json형식의 문자열을 json객체로 parsing하기 졸리운_곰 2018.02.12 90
206 [Java] Quartz (쿼츠)를 사용하여 자바 스케줄링(scheduling) 하기 졸리운_곰 2018.02.12 245
205 스프링(Spring) 프레임워크 기본 개념 강좌 (7) - Patterns 졸리운_곰 2017.10.02 92
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED