본문 바로가기

Dev/JPA

RS) 연관관계 매핑 기초

객체와 테이블 연관관계의 차이를 이해

객체의 참조와 테이블의 외래 키를 매핑

용어 이해

  • 방향 : 단방향, 양방향
  • 다중성 : 다대일(N:1), 일대다(1:N), 일대일(1:1), 다대다(N:M) 이해
  • 연관관계의 주인(Owner) : 객체 양방향 연관관계는 관리 주인이 필요

문제가 되는 코드를 살펴보자

  • Member 엔티티 안에 teamId를 들고있으면, 연관관계가 없을 경우에 아래와 같이 문제가 있다.
  • 객체지향 스럽지 않다는 뜻이다.
@Entity
public class Member {
    @Id
    @GeneratedValue
    @Column(name = "MEBMER_ID")
    private Long id;

    @Column(name = "USERNAME")
    private String username;
	// teamId를 들고 있다.
    @Column(name = "TEAM_ID")
    private Long teamId;
public class JpaMain {
    public static void main(String[] args) {
        EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello");
        EntityManager em = emf.createEntityManager();

        EntityTransaction tx = em.getTransaction();
        tx.begin();

        try{

            Team team = new Team();
            team.setName("TeamA");
            em.persist(team);

            Member member = new Member();
            member.setUsername("member1");
            member.setTeamId(team.getId()); // 이부분이 애매함.. 외래키 식별자를 직접 다루게 된다..
            em.persist(member);

객체를 테이블에 맞추어 데이터 중심으로 모델링하면, 협력관계를 만들 수 없다.

  • 테이블은 외래 키로 조인을 사용해서 연관된 테이블을 찾는다.
  • 객체는 참조를 사용해서 연관된 객체를 찾는다.
  • 테이블과 객체 사이에는 이런 큰 간격이 있다.

단방향 연관관계

코드를 통해 단방향 연관관계를 설정한 부분을 확인해보자

//    @Column(name = "TEAM_ID")
//    private Long teamId;

	// 에러가 나는 이유는 JPA한테 관계를 알려줘야 하기 때문
    // MEMBER가 N이고 team이 1이다.
    @ManyToOne
    @JoinColumn(name = "TEAM_ID")
    private Team team;

'Dev > JPA' 카테고리의 다른 글

RS) 연관관계 매핑시 주의할 점  (0) 2022.02.15
RS) 양방향 연관관계와 연관관계의 주인  (0) 2022.02.06
RS) 실전예제를 통한 문제점 분석  (0) 2022.02.06
RS) 기본키 매핑  (0) 2022.02.03
RS) 필드와 컬럼 매핑  (0) 2022.02.03