我有型“文件夹”的对象之间一个非常简单的父 - /子关系,它看起来像这样:休眠删除后了Session.update(父)子对象
- 一个文件夹可以有0-1父文件夹。
- 一个文件夹可以有0-n个子文件夹 (子文件夹)。
所以,基本上,Java类文件夹的简化版本是这样的:
public class Folder{
long id;
Set<Folder> childFolders;
Folder parentFolder;
String path;
// Getter, setter and other (for this question)
// not relevant properties omitted
public boolean equals(Object obj){
if (obj == null) return false;
if (obj == this) return true;
if (obj instanceof Folder){
Folder folder = (Folder)obj;
return folder.getPath().equals(getPath());
}
return false;
}
public int hashCode(){
return getPath().hashCode();
}
}
我简单的测试层次结构是这样的:
folder1
folder2
- folder3
subfolder3-1
使用Hibernate,我呼吁:
session.update(folder1);
session.update(folder2);
session.update(folder3);
前两个调用成功。
最后一次对folder3的调用不会引发异常,但它会从folder3的内部set“childFolders”中删除子文件夹3-1。 这意味着,folder3.childFolders.size() = 0
尽管在最后一次更新呼叫之前是1。 重要提示:在数据库中,文件夹“subfolder3-1”仍然存在!
这怎么可能?
这里是我的映射文件:
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="test.Folder" table="FOLDERS">
<id name="id" type="long" access="field">
<column name="FOLDER_ID" />
<generator class="native" />
</id>
<set name="childFolders" table="FOLDERS" inverse="true" cascade="save-update">
<key column="PARENT_FOLDER_ID"></key>
<one-to-many class="test.Folder" />
</set>
<many-to-one name="parentFolder" column="PARENT_FOLDER_ID" />
<property name="path" column="FOLDER_PATH" />
</class>
</hibernate-mapping>
'test.Folder'中的'equals()'和'hashcode()'方法是什么样的? – 2011-06-01 20:34:06
@matt b我在原文中加了两个方法 – Timo 2011-06-01 21:17:37