본문 바로가기

Back-end109

17. 고아 객체(Orphan) 0. 개요 - 이번 포스팅에서는 고아 객체란 무엇인지 알아보자. 1. 고아 객체(Orphan) a) 개념 - 고아 객체는 부모 객체와 연관 관계가 끊어진 자식 객체를 의미한다. b) orphanRemoval 옵션 - JPA는 자식 객체가 고아 객체의 상태가 되면 해당 객체를 자동으로 삭제하는 기능을 가진다. - 이는 다음 사진처럼 옵션으로 설정이 가능하다. - 위의 코드는 childList에서 삭제된 객체를 연관 관계가 끊긴 것으로 판단하여 객체 자체를 삭제한다. - 옵션을 설정한 후, 다음과 같은 코드를 실행해보자. - 위의 코드를 실행하면 다음과 같아 DELETE 쿼리가 자동으로 발생하는 것을 확인할 수 있다. - 다음 사진과 같이, 연관 관계가 끊긴 자식 객체가 DB에서 삭제된 것을 확인할 수 있다.. 2022. 4. 13.
16. 영속성 전이(Cascade) 0. 개요 - 웹 개발 공부를 했다면 Cascade라는 단어가 익숙할 수 있다. - CSS(Cascade Style Sheet)에서 사용되는 단어이기 때문이다. - Cascade라는 단어는 폭포처럼 흐른다는 의미를 갖는다. - 이를 의역해보면 연쇄적인, 종속적인, 상속적인, 전이되는 등으로 해석할 수 있다. - 이처럼 어떤 속성을 전수하는 것을 Cascade라고 표현한다. - 이번 포스팅에서는 JPA에서 사용하는 Cascade에 대해서 알아보자. 1. 영속성 전이(Cascade) a) 영속성 전이란? - 어떤 Entity를 영속성 Context에 등록할 때, 연관 객체도 함께 등록하는 기능이다. - 즉, 어떤 Entity를 영속 상태로 만들 때, 연관 객체 또한 함께 영속 상태가 되도록 하는 것이다. -.. 2022. 4. 12.
15. 지연 로딩 & 즉시 로딩(N + 1 문제) 0. 개요 - 이전 포스팅에서 Proxy에 대해 알아보았다. - 이번 포스팅에서는 Proxy를 이용한 지연 로딩과 즉시 로딩에 대해서 알아보자. 1. 지연 로딩 a) 예시 코드 - 다음과 같은 객체를 가지는 프로젝트가 있다고 해보자. @Entity public class Player { @Id @GeneratedValue @Column(name = "PLAYER_ID") private Long id; @Column(name = "PLAYER_NAME") private String name; @ManyToOne @JoinColumn(name = "TEAM_ID") private Team team; // Getter & Setter 생략 } @Entity public class Team { @Id @Gene.. 2022. 4. 11.
14. 프록시(Proxy) 0. 개요 - 이번 포스팅에서는 JPA Proxy에 대해서 알아보자. - proxy는 JPA 개념 중에서도 어려운 개념에 속한다. 차근차근 배워보자. 1. Proxy를 사용하는 이유 a) 언제, 왜 사용할까? - 예를 들어, Player와 Team 객체를 모두 조회하는 비즈니스 로직이 있다고 해보자. - 경우에 따라 Player와 Team 객체가 모두가 필요할 때도, 두 객체 중 하나만 필요할 때도 있을 것이다. - 그러나 이미 두 객체를 모두 조회하도록 비즈니스 로직을 선언하였기에, 매번 Player와 Team 객체를 모두 조회한다. - 이처럼 필요하지 않은 객체에 대한 조회는 자원 낭비를 발생시킨다. - JPA는 이러한 상황을 해결하기 위해 지연 로딩을 사용하는데, 이때 Proxy라는 개념이 사용된다.. 2022. 4. 8.
13. @MappedSuperClass 0. 개요 - 이번 포스팅에서는 @MappedSuperClass라는 기능에 대해서 알아보자. 1. @MappedSuperClass - @MappedSuperClass는 공통 매핑 정보를 필요로 할 때 사용하는 기능이다. - 이는 상속 관계 매핑과 DB와는 별도의 기능으로, 객체의 관점만 집중하는 기능이다. a) @MappedSuperClass란? - 모든 Entity에 동일한 필드가 존재하는 경우, 이를 Entity를 정의할 때마다 중복적으로 작성한다. - 이러한 중복 필드를 공통으로 관리하여 중복적인 작성을 방지하는 기능이다. b) 예시 코드 - 다음 예시 코드를 통해서 @MappedSuperClass의 역할을 이해해보자. @Entity public class A { @Id @GeneratedValue.. 2022. 4. 7.
12. 상속 관계 매핑 0. 개요 - 상속 관계는 OOP에 존재하지만, RDB에는 존재하지 않는 개념이다. - 그러므로 JPA는 객체 간의 상속 관계를 RDB에 적용할 수 있도록 변환하는 작업을 수행한다. - 이번 포스팅에서는 JPA를 이용하여 상속 관계를 매핑하는 방법에 대해서 알아보자. 1. 상속 관계 매핑 - DB를 설계할 때 관계를 논리 모델과 물리 모델을 이용하여 표현한다. → 논리 모델: 사물의 관계를 도식화하여, 사물이 서로 어떻게 interact 하는지 표현한다. → 물리 모델: 논리 모델을 기반하여 ERD로 표현한다. a) 논리 모델 구현 - 슈퍼 타입, 서브 타입 - 상속 관계를 RDB로 구현할 때 우선 논리 모델을 구현한다. - 이때 논리 모델의 슈퍼/서브 타입을 사용하여 객체의 상속 관계를 유사하게 표현할.. 2022. 4. 6.
11. 연관 관계의 종류(일대일, 다대다) 0. 개요 - 이전 포스팅에 이어서 연관 관계의 종류에 대해서 알아보자. 1. 일대일(1:1, OneToOne) 관계 a) 일대일 연관 관계란 - 일대일 관계는 그 반대도 일대일 관계다. - 일대일 관계의 경우, 주 테이블 또는 대상 테이블 중 한쪽에서 FK를 관리한다. - 즉, 연관 관계의 주인을 선택하는 과정이 자유롭다. - 다만, DB에서 FK에 유니크(UNIQ) 제약조건이 추가되어야 한다. * 알아두자! - UNIQUE 제약 조건이란, 해당 칼럼에 들어가는 값(value)이 고유 값이어야 한다는 제약이다. - 즉, 중복 값이 존재하지 않는다. b) 일대일 관계의 예시 - 예를 들어, 선수 1명당 1개의 라커를 할당받는다는 규칙을 테이블로 구현하면 다음과 같다. - 이를 객체로 구현하면 다음과 같다.. 2022. 4. 5.
10. 연관 관계의 종류(일대다, 다대일) 0. 개요 - 이번 포스팅에서는 다양한 연관 관계의 종류에 대해서 알아보도록 하자. a) 연관 관계의 종류 - 연관 관계에는 다음과 같은 종류가 있다. → 다대일(N:1, @ManyToOne) → 일대다(1:N, @OneToMany) → 일대일(1:1, @OneToOne) → 다대다(N:N, @ManyToMany) - 위의 4가지 형태의 연관 관계에 대하여 알아보도록 하자. 1. 연관 관계 매핑 시 고려사항 a) 다중성 - 위에서 4가지 종류의 연관 관계가 있다는 것을 알았다. - 이 연관 관계를 매핑할 때에는 다중성을 고려해야 하는데, 다중성이란 다음과 같다. ex) 하나의 주문이 여러 개의 아이템을 가지는 관계 ex) 하나의 팀이 여러 명의 선수를 가지는 관계 - 이처럼 연관 관계의 대상이 다수의 데.. 2022. 4. 4.
9. 양방향 연관 관계 사용 시 주의사항 0. 개요 - 이전 포스팅에서 JPA를 이용한 양방향 연관 관계를 구현하는 방법에 대해 알아보았다. - 이번 포스팅은 양방향 연관 관계를 구현할 때 자주 실수하는 부분에 대해서 알아보자. * 이전 포스팅과 이어지는 내용입니다! 1. 연관 관계의 주인만 FK의 값을 생성할 수 있다. a) 예시 코드 - 양방향 매핑을 구현하면 mappedBy 옵션을 사용하여 연관 관계의 주인을 명시한다. - 이로써 JPA에서도 FK처럼 작동한다고 판단하여 자주 하는 실수 중 하나이다. - 다음 코드 예시를 살펴보자. - 우선 선수 객체(player1)를 만들었다. - 그리고 팀 객체(team)를 만들었다. - team 객체를 이용하여 앞서 만들었던 선수 객체를 저장하였다. - 이 코드는 올바르게 작동할까? - 위의 결과처럼.. 2022. 4. 1.