Fall in IT.

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

프레임워크/Spring Data JPA

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

D.Y 2016. 3. 10. 15:12

오늘은 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

{

@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 생략)

}


모두 즐거운 코딩 하세요~



Comments