작성
·
884
0
@MappedSuperclass
@Getter
public abstract class BaseEntity implements Serializable {
@Id @GeneratedValue
private Long id;
@CreatedDate
private LocalDateTime createdAt;
@LastModifiedDate
private LocalDateTime updatedAt;
@Column(length = 10)
@Value("ACTIVE")
private String status;
public BaseEntity(LocalDateTime createdAt, LocalDateTime updatedAt) {
this.createdAt = createdAt;
this.updatedAt = updatedAt;
}
protected BaseEntity() {}
}
만약 처음 테이블 설계와 같이 외례키를 조합하여 테이블을 관리하게 되면 Entity does not have primary key라는 경고 메시지가 발생합니다.
여기서 BaseEntity를 상속받는 다면 기본 키도 같이 상속받기 때문에 경고 메시지는 사라지지만 ERD와 달리 기본 키를 갖게 됩니다.
ERD 설계와 같이 외례키 조합만으로 도메인을 구성할 수 있는 방법이 있을까요?
혹은 위의 ERD를 수정하여 group_member_id 기본키를 넣어주는 편이 더 좋은 설계인것인지 궁금합니다.
답변 1
0
안녕하세요. 고산하님
복합키의 경우 JPA 책 7.3 복합 키와 식별 관계 매핑을 참고해주세요.
추가로 기본키를 추가하는 장단점은 다음을 참고해주세요.
https://www.inflearn.com/questions/185233
감사합니다.