当我在没有实现hashcode()和toString()的情况下执行我的程序时,它就可以正常工作了。但是,一旦我包括hashcode()和toString(),我就会得到这个“非法访问加载集合”错误。
我的hbm文件是
1) booking.hbm.xml
<many-to-one name="userId" class="User" column="user_id"
insert="true" update="true" cascade="save-update" >
</many-to-one>
<many-to-one name="flightId" class="FlightSchedule"
column="flight_id" cascade="all" not-null="true">
</many-to-one>
<set name="passenger" table="passenger79215" lazy="false"
inverse="true" cascade="save-update">
<key column="reference_id" />
<one-to-many class="Passenger" />
</set>2) Passenger.hbm.xml
<many-to-one name="referenceid" class="Booking" lazy="false"
insert="true" update="true" column="reference_id "
cascade="save-update">
</many-to-one>3) User.hbm.xml
<set name="booking" table="bookings79215" lazy="true"
inverse="false" cascade="save-update">
<key column="user_id" />
<one-to-many class="Booking" />
</set>有人能解释一下错误吗?
发布于 2011-10-22 14:05:02
您的哈希代码和equals方法不能正常工作。确保他们是正确的。toString()与集合类无关,但与哈希代码和等于有关系。
我假设您已经重写了hashcode和equals,而不仅仅是hashcode。
Object#hashCode() (Java Platform SE 7 )
发布于 2011-10-22 14:23:58
我认为您不应该在等于和/或hashCode中使用id字段(由hibernate管理)。
等于和hashCode应该实现为业务逻辑相等。
发布于 2013-09-04 16:32:44
我也犯了同样的错误,但分辨率不同。就像OP一样,我使用Apache的hashcode构建器。我的对象是一对多关系的父母和孩子。子节点将父键作为成员,以便正确设置外键。
问题是,hashcode构建器使用所有成员字段,但是当创建Child时,它的父级还没有完成加载。当hashcode构建器引用时,父成员Hibernate抛出异常,因为父成员仍在加载。
修复方法是将父引用从hashcode的hashCode构建器中排除出来,并等于:
@Override
public boolean equals(final Object obj)
{
return EqualsBuilder.reflectionEquals(this, obj, "parent" );
}
@Override
public int hashCode()
{
return HashCodeBuilder.reflectionHashCode(this, "parent" );
}https://stackoverflow.com/questions/7860064
复制相似问题