gpt4 book ai didi

java - 持久化对象后,Hibernate assertEquals失败

转载 作者:行者123 更新时间:2023-12-03 06:12:44 24 4
gpt4 key购买 nike

我将Hibernate用于我的DAO实现。我创建了映射,并覆盖了equals方法。

当我使用assertEquals(object,object)时,即使对象相同,它也会失败。
Book.java

package tn.jebouquine.pojo;

@Entity
public class Book {
@Id
private String ISBN;
@NotEmpty
private String name;
@NotNull
@DecimalMin(value = "0.00")
private BigDecimal price;
private String description;
@ManyToMany(fetch = FetchType.EAGER,cascade = CascadeType.ALL)
@NotEmpty
private List<Author> authors = new ArrayList<Author>();
@ManyToMany(fetch = FetchType.EAGER,cascade = CascadeType.ALL)
private List<Category> categories = new ArrayList<Category>();
@ElementCollection(fetch = FetchType.EAGER)
private List<BookComment> bookComments = new ArrayList<BookComment>();

public String getISBN() {
return ISBN;
}

public void setISBN(String ISBN) {
this.ISBN = ISBN;
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

public BigDecimal getPrice() {
return price;
}

public void setPrice(BigDecimal price) {
this.price = price;
}

public String getDescription() {
return description;
}

public void setDescription(String description) {
this.description = description;
}

public List<Author> getAuthors() {
return authors;
}

public void setAuthors(List<Author> authors) {
this.authors = authors;
}

public List<Category> getCategories() {
return categories;
}

public void setCategories(List<Category> categories) {
this.categories = categories;
}

public List<BookComment> getBookComments() {
return bookComments;
}

public void setBookComments(List<BookComment> bookComments) {
this.bookComments = bookComments;
}

@Override
public boolean equals(Object o) {
if (this == o) return true;
if (!(o instanceof Book)) return false;

Book book = (Book) o;

if (!ISBN.equals(book.ISBN)) return false;
if (!authors.equals(book.authors)) return false;
if (bookComments != null ? !bookComments.equals(book.bookComments) : book.bookComments != null) return false;
if (categories != null ? !categories.equals(book.categories) : book.categories != null) return false;
if (description != null ? !description.equals(book.description) : book.description != null) return false;
if (!name.equals(book.name)) return false;
if (!price.equals(book.price)) return false;

return true;
}

@Override
public int hashCode() {
int result = ISBN.hashCode();
result = 31 * result + name.hashCode();
result = 31 * result + price.hashCode();
result = 31 * result + (description != null ? description.hashCode() : 0);
result = 31 * result + (authors != null ? authors.hashCode() : 0);
result = 31 * result + (categories != null ? categories.hashCode() : 0);
result = 31 * result + (bookComments != null ? bookComments.hashCode() : 0);
return result;
}

@Override
public String toString() {
return "Book{" +
"ISBN='" + ISBN + '\'' +
", name='" + name + '\'' +
", price=" + price +
", description='" + description + '\'' +
", authors=" + authors +
", categories=" + categories +
", bookComments=" + bookComments +
'}';
}
}

HibernateBookDAO.java
package tn.jebouquine.dao.hibernate;
public class HibernateBookDAO implements BookDAO {

@Override
public void create(Book book) {
Session session = SessionUtilities.openSessionAndBeginTransaction();

session.save(book);

SessionUtilities.commitAndCloseSession(session);
}

@Override
public Book retrieve(String ISBN) {
Session session = SessionUtilities.openSessionAndBeginTransaction();

Book book = session.get(Book.class , ISBN);

SessionUtilities.commitAndCloseSession(session);
return book;
}

@Override
public void update(Book book) {
Session session = SessionUtilities.openSessionAndBeginTransaction();

session.update(book);

SessionUtilities.commitAndCloseSession(session);
}

@Override
public void delete(Book book) {
Session session = SessionUtilities.openSessionAndBeginTransaction();

session.delete(book);

SessionUtilities.commitAndCloseSession(session);
}
}

BookTest.java
public class BookTest {


private Book book;
private static BookDAO bookDAO;
private static Logger logger;
@BeforeClass
public static void beforeClass() {
bookDAO = new HibernateBookDAO();
logger = LoggerFactory.logger(BookTest.class);
}
@AfterClass
public static void afterClass(){
bookDAO = null;
logger = null;
}

@Before
public void setUp() {
Author author = new Author();
author.setName("The lonely developer");
book = new Book();
book.setISBN("isbn:9780137081073");
book.setName("The Adventures of the little guy in Java persistance world: Testing At midnight for the next saturday :(");
book.setPrice(new BigDecimal("10.00"));
book.getAuthors().add(author);

}

@Test
public void createTest() {
bookDAO.create(book);
}

@Test
public void retrieveTest() {
book.setISBN("isbn:9780137081074");
bookDAO.create(book);
Book book1 = bookDAO.retrieve(book.getISBN());
assertEquals(book, book1);
}

所有其他类都具有equals和实现的哈希码。我正在使用gradle构建项目。

最佳答案

问题解决了。当映射已排序的List时,事实证明我需要指定要用于排序的列。所以最终结果看起来像这样。

@ManyToMany(fetch = FetchType.EAGER,cascade = CascadeType.ALL)
@OrderColumn(name="INDEX")
@NotEmpty
private List<Author> authors = new ArrayList<Author>();

或者,我可以使用未排序的 Set

关于java - 持久化对象后,Hibernate assertEquals失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33332458/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com