web-dev-qa-db-ja.com

「Java.lang.StackOverflowError:null」のLombok.hashCodeの問題

私は2つのテーブルがあり、以下のような1対1の関係があります。

@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()));」を実行すると、実行すると、以下のエラーが発生しました

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]

上記と同じように100行ほど繰り返します。これは、Lombok.hashCodeを使用できないことを意味しますか?

保存された本: '32768'、 'Spring JPA'、 '32768'保存された本の詳細: '32768'、 '1157'

23
mikezang

あなたは、bookとbookdetailsの間に循環依存関係があります。 bookBookDetailから除外するか、bookDetailBookから除外する必要があります。

47
Roel Spilker