假设这些是我的父母和我的孩子对象:
家长:
@Entity
@Table( name = "import_table" )
public class ImportTable {
@Cascade( { CascadeType.ALL, CascadeType.DELETE_ORPHAN } )
@OneToMany(
mappedBy = "table",
fetch = FetchType.EAGER
)
public List<ImportTableColumn> getColumns()
{
return columns;
}
... setter is defined but I don't think it's important for the example
}
孩子:
@Entity
@Table( name = "import_table_column" )
public class ImportTableColumn {
@ManyToOne
@JoinColumn(
name = "import_table_name",
nullable = false
)
public ImportTable getTable()
{
return table;
}
}
以下伪代码将起作用
- 创建 ImportTable 的实例,添加 2 列,创建会话,保存,关闭会话;
- 在不同的会话中读取保存的实例,删除一列;
- 将其保存在另一个会话中;
- 检查列数并且等于一。
但以下方法不起作用:
- 创建 ImportTable 的实例,添加 2 列,创建会话,保存,关闭会话;
- 在不同的会话中读取保存的实例;
- 手动重新创建保存的对象;
- 删除列;
- 将其保存在另一个会话中;
- 检查列数并且等于一。
原因是我们有一个 Java 服务器/Flex 客户端应用程序,我们需要加载对象,将其发送给客户端,让客户端做它必须做的任何事情,将对象发送回服务器,然后保存。
我认为当我重新创建对象时,Hibernate 会迷路。据我所知,当从数据库中检索对象时,Hibernate 确实在对象中注入了一些东西。当我重新创建对象时,我不会复制任何不是对象类中声明的字段的内容。这是重新创建对象的代码(用于我的单元测试):
private ImportTable recreate( ImportTable original ) throws IOException
{
final ImportTable copy = new ImportTable();
copy.setDatabaseTableName( original.getDatabaseTableName() );
copy.setDisplayTableName( original.getDisplayTableName() );
if( original.getColumns() != null ) {
copy.setColumns( new ArrayList<ImportTableColumn>( original.getColumns().size() ) );
for( ImportTableColumn originalColumn : original.getColumns() ) {
final ImportTableColumn copyColumn = new ImportTableColumn();
copyColumn.setTable( copy );
copyColumn.setDatabaseColumnName( originalColumn.getDatabaseColumnName() );
copyColumn.setDatatype( originalColumn.getDatatype() );
copyColumn.setExcelColumnName( originalColumn.getExcelColumnName() );
copyColumn.setId( originalColumn.getId() );
copyColumn.setLength( originalColumn.getLength() );
copyColumn.setPk( originalColumn.isPk() );
copyColumn.setRequired( originalColumn.isRequired() );
copyColumn.setPrecision( originalColumn.getPrecision() );
copy.getColumns().add( copyColumn );
}
}
return copy;
}
我相信当我重新创建对象时,hibernate 会迷路。我想要hibernate做的是将数据库中的内容与对象中的内容进行比较,并仅保存差异。有没有办法做到这一点?