inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

자바 ORM 표준 JPA 프로그래밍 - 기본편

실전 예제 3 - 다양한 연관관계 매핑

안녕하세요 선생님. 질문이 있습니다.

297

이재윤

작성한 질문수 8

1

안녕하세요 선생님?

선생님 강의 시리즈 잘 듣고 덕분에 학교 졸업 전에 많은 걸 배웠습니다.

 

다름이 아니라 이 강의를 참조하면서, 개인 프로젝트를 만들고 있습니다.

다름이 아니라 신고 기능을 구현하던 중 막혀서 질문 드립니다.

 

신고 기능을 구현하기 위해서 저는 UserReport 라는 테이블을 만들고, 그 안에 필드로 repoter 와 reportedUser (둘다 같은 User 객체 타입)을 선언 했는데, 스프링 서버를 실행시키니 작동은 되나, 테이블 생성이 안됩니다.

아무래도 제 생각이지만 같은 객체타입으로 선언을 해서 그런 것 같은데 어떻게 하면 좋을까요??

 

일단 제가 여기서 생각한 방법은 reporter, reportedUser 을 모두 각각 reporter_id, reportedUser_id 로 두는 방법인데 이게 더 나을까요?

 

스택오버플로우에 올려도 아무도 답변을 안 해줘서 선생님에게 질문 남깁니다. 감사합니다^^

 

package yoon.community.entity.report;

import lombok.AccessLevel;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.hibernate.annotations.OnDelete;
import org.hibernate.annotations.OnDeleteAction;
import org.springframework.format.annotation.DateTimeFormat;
import yoon.community.entity.user.User;

import javax.persistence.*;
import java.time.LocalDate;

@AllArgsConstructor
@NoArgsConstructor(access = AccessLevel.PROTECTED)
@Data
@Entity
public class UserReport {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
Long id;

@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "reporter_id", nullable = false)
@OnDelete(action = OnDeleteAction.NO_ACTION)
private User reporter;

@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "reported_id", nullable = false)
@OnDelete(action = OnDeleteAction.CASCADE)
private User reportedUser;

@Column(nullable = false)
private String explain;

@DateTimeFormat(pattern = "yyyy-mm-dd")
private LocalDate createDate; // 날짜

public UserReport(User reporter, User reportedUser, String explain) {
this.reporter = reporter;
this.reportedUser = reportedUser;
this.explain = explain;
}

@PrePersist // DB INSERT 되기 직전에 실행. DB에 값을 넣으면 자동으로 실행됨
public void createDate() {
this.createDate = LocalDate.now();
}
}

java JPA

답변 1

1

David

안녕하세요. 이재윤님, 공식 서포터즈 David입니다.

지금 매핑하신걸로 보면 별 문제 없어보이는데, 이전에는 어떤 방식으로  매핑하신건가요?

감사합니다.

0

이재윤

선생님.. String explain;

이 부분에서 explain 이 MySQL 예약어라서 오류가 뜬거였네요. 감사합니다 ^^

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

58

2

inheritance startegy 선택시 고려사항

0

42

1

Entity 동등성 비교

0

47

1

실무 조언 관련 질문입니다.

0

68

1

H2데이터베이스 파일 생성

0

78

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

70

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

63

1

JPQL 메소드와 락

0

63

1

Delivery @OneToOne

0

73

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

105

2

UnsupportedOperationException 발생

0

97

3

H2 Database 연결이 안됩니다.

0

103

2

연관관계 매핑 질문드립니다.

0

95

2

h2데이터베이스 실행오류

0

116

2

persistence.xml

0

121

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

90

1

영속성 컨텍스트

0

77

1

JPA 프록시

0

107

1

Native Query와 MyBatis

0

83

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

97

1

임베디드 타입 예시 코드 관련 질문

0

126

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

103

3

인텔리제이 패키지 커서 단축키 질문

0

113

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

156

1