0

假设这些是我的父母和我的孩子对象:

家长:

@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做的是将数据库中的内容与对象中的内容进行比较,并仅保存差异。有没有办法做到这一点?

4

1 回答 1

2

AbstractPersistentCollection当所有者实体第一次附加到会话时,Hibernate 将集合实例包装到适当的子类中。

然后跟踪PersistentCollection已删除的集合元素;没有它,Hibernate 将只能对它们执行插入/更新(在大多数情况下;对于某些 id 生成器类,即使这是不可能的)。

你基本上不走运。你唯一能做的就是ImportTable从数据库中加载一个现有的实体(

也就是说,我不太明白为什么你首先需要克隆你的实体(我不知道 Flex ......你是在将你的实体编组为 XML / JSON / 等吗?)所有PersistentCollection实现都是Serializable,因此可以是通过电线发送并返回。有一些方法可以将它们编组为 XML 并返回。

于 2009-12-15T03:47:23.143 回答