@MappedSuperclass • 공통 매핑 정보가 필요할 때 사용(id, name) @MappedSuperclass 사용시 주의 사항 • 상속관계 매핑X • 엔티티X, 테이블과 매핑X • 부모 클래스를 상속 받는 자식 클래스에 매핑 정보만 제공 • 조회, 검색 불가(em.find(BaseEntity) 불가) • 직접 생성해서 사용할 일이 없으므로 추상 클래스 권장 @MappedSuperclass 란 • 테이블과 관계 없고, 단순히 엔티티가 공통으로 사용하는 매핑 정보를 모으는 역할 • 주로 등록일, 수정일, 등록자, 수정자 같은 전체 엔티티에서 공통 으로 적용하는 정보를 모을 때 사용 • 참고: @Entity 클래스는 엔티티나 @MappedSuperclass로 지 정한 클래스만 상속 가능 exampl..
상속 관계 매핑 • 관계형 데이터베이스는 상속 관계 없음 • 슈퍼타입 서브타입 관계라는 모델링 기법이 객체 상속과 유사 • 상속관계 매핑: 객체의 상속과 구조와 DB의 슈퍼타입 서브타입 관계를 매핑 상속 관계 매핑 종류 • 슈퍼타입 서브타입 논리 모델을 실제 물리 모델로 구현하는 방법 1. 각각 테이블로 변환 -> 조인 전략 2. 통합 테이블로 변환 -> 단일 테이블 전략 3. 서브타입 테이블로 변환 -> 구현 클래스마다 테이블 전략 • 주요 어노테이션 • @Inheritance(strategy=InheritanceType.XXX) 1. JOINED: 조인 전략 2. SINGLE_TABLE: 단일 테이블 전략 3. TABLE_PER_CLASS: 구현 클래스마다 테이블 전략 • @DiscriminatorC..
Error log java.lang.IllegalStateException: Cannot call sendError() after the response has been committed Game @Getter @Entity @Table(name = "GAMES") @NoArgsConstructor public class Game { // 게임 아이디(PK) @Id @Column(name = "GAME_ID") private Long gameId; // 게임 이름 @Column(name = "GAME_NAME") private String gameName; // 게임 정보 @Column(name = "GAME_INFO") private String gameInfo; ... @OneToMany(mapped..
다대일[N:1] 단방향 1) 다대일 단방향 정리 • 가장 많이 사용하는 연관관계 • 다대일의 반대는 일대다 2) 다대일 단방향 예제 • Member public class Member { @Id @GeneratedValue @Column(name="MEMBER_ID") private Long id; @Column(name="USERNAME") private String name; @ManyToOne @JoinColumn(name = "TEAM_ID") private Team team; } • Team @Entity public class Team { @Id @GeneratedValue @Column(name="TEAM_ID") private Long id; private String name; } 양방향..
객체를 테이블에 맞출시(연관관계 X) • Member @Entity public class Member { @Id @GeneratedValue private Long id; @Column(name = "USERNAME") private String name; @Column(name = "TEAM_ID") private Long teamId; … } • Team @Entity public class Team { @Id @GeneratedValue private Long id; private String name; … } • Example //팀 저장 Team team = new Team(); team.setName("TeamA"); em.persist(team); //회원 저장 Member member =..
기본키 매핑 어노테이션 • @Id • @GeneratedValue @Id @GeneratedValue(strategy = GenerationType.AUTO) private Long id; 기본키 매핑 방법 1) 직접 할당 • @Id만 사용 2) 자동 생성(@GeneratedValue) • IDENTITY: 데이터베이스에 위임, MYSQL - 기본 키 생성을 데이터베이스에 위임 - 주로 MySQL, PostgreSQL, SQL Server, DB2에서 사용 (예: MySQL의 AUTO_ INCREMENT) - JPA는 보통 트랜잭션 커밋 시점에 INSERT SQL 실행 - AUTO_ INCREMENT는 데이터베이스에 INSERT SQL을 실행 한 이후에 ID 값을 알 수 있음 - IDENTITY 전략은 ..