6
は、以下のように1対1の関係を持っている:私は以下のようにデータを入力するためにフォームを使用 Lombok.hashCodeの問題「によってjava.lang.StackOverflowError:ヌル」私は2つのテーブルを持っている
@Entity
@Data
@NoArgsConstructor
@AllArgsConstructor
public class Book {
@Id
@GeneratedValue(strategy = GenerationType.TABLE)
private int id;
private String name;
@OneToOne(cascade = CascadeType.ALL)
@JoinColumn(name = "book_dtail_id")
private BookDetail bookDetail;
}
@Entity
@Table(name = "book_detail")
@Data
@NoArgsConstructor
@AllArgsConstructor
public class BookDetail {
@Id
@GeneratedValue(strategy = GenerationType.TABLE)
private Integer id;
@Column(name = "number_of_pages")
private Integer numberOfPages;
@OneToOne(mappedBy = "bookDetail")
private Book book;
}
@Data
@NoArgsConstructor
@AllArgsConstructor
public class BookForm {
Book book;
BookDetail bookDetail;
}
コントローラは、次のようになります。
String handleNewBook(Model model){
Book book = new Book();
BookDetail bookDetail = new BookDetail();
BookForm bookForm = new BookForm(book, bookDetail);
model.addAttribute("bookForm", bookForm);
return "index";
}
String handleSaveBookCreate(BookForm bookForm, Model model){
bookForm.getBook().setBookDetail(bookForm.getBookDetail());
bookForm.getBookDetail().setBook(bookForm.getBook());
bookService.save(bookForm.getBook()));
return "index";
}
最終
は、以下のように私のフォームです:<form role="form" action="#" th:object="${bookForm}" th:action="@{/book}" method="POST">
<input type="text" th:field="*{book.name}"/>
<input type="text" th:filed="*{bookDetail} == null ? '' : *{bookDetail.numberOfPages}" placeholder="Enter Book Page Numbers"/>
<button type="submit">Submit</button>
</form>
すべての問題はないようですが、私は "bookService.save(bookForm.getBook()));"実行され、私は約100行、上記と同様に....これは私がLombok.hashCodeを使用することができないことを意味しています
java.lang.StackOverflowError: null,
at com.zangland.study.jpa.entity.BookDetail.hashCode(BookDetail.java:17) ~[classes/:na]
at com.zangland.study.jpa.entity.Book.hashCode(Book.java:16) ~[classes/:na]
at com.zangland.study.jpa.entity.BookDetail.hashCode(BookDetail.java:17) ~[classes/:na]
at com.zangland.study.jpa.entity.Book.hashCode(Book.java:16) ~[classes/:na]
繰り返し、以下のようなエラーを得ましたか。
保存されているブック: '32768'、 '春JPA'、 '32768' 保存BookDetail: '32768'、 '1157'
私はそれを行うことができます、それはロンボクの機能ですか? – mikezang
'@EqualsAndHashCode(exclude =" book ")'を追加することができます。詳細については、[EqualsAndHashCodeのドキュメント](https://projectlombok.org/features/EqualsAndHashCode.html)を参照してください。 –