작성
·
249
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();
}
}
선생님.. String explain;
이 부분에서 explain 이 MySQL 예약어라서 오류가 뜬거였네요. 감사합니다 ^^