如何使用Hibernate以最佳方式更新对象中的单个属性?

时间:2009-05-12 21:18:21

标签: java hibernate optimization

我有一个对象:

public class Data {
    private long           id;
    private long           referenceCount;
    private Blob           dataCache;

    /* getters and setters for the above */
}

对应这是一个映射:

<hibernate-mapping>
  <class name=Data" table=DATA">

    <id name=id" type="long">
      <column name=DATA_ID" precision="20" scale="0" />
      <generator class="assigned" />
    </id>

    <property name="referenceCount" type="long" generated="always" insert="false" update="false">
      <column name="REFERENCE_COUNT" precision="10" scale="0" not-null="true" />
    </property>
    <property name=dataCache" type="blob">
      <column name="DATA" />
    </property>
  </class>
</hibernate-mapping>

'dataCache'的内容可能非常大。

这里变得棘手:referenceCount的值由触发器设置, 由与Data实体没有映射关系的对象调用。尽快 当我保存这个对象时,我必须刷新一个数据对象 - 可能会也可能不会 已经被会话加载 - 以保持引用计数 正确。撇开这是否被视为一个好主意,我必须确保 在我的本地会话中,referenceCount的值是最新的,但是我 不想重新加载dataCache blob。我可以设置延迟属性 那个属性,但我不确定它会按照我希望的方式行事。

我该怎么做?我想我可以看到它的一种方式是:“如果没有加载该对象,如何从会话缓存中删除一个对象?”

2 个答案:

答案 0 :(得分:2)

根据this forum postjava.sql.Blob/Clob类型的字段应支持延迟加载。因此,人们会期望在Session.refresh()的持久化实例上执行Data,如文档所指定的那样,将从底层数据库重新读取给定实例的状态,但不会加载{{1} }}

不过,我建议您将dataCache移到单独的类并将其映射为强制一对一关系。确保您没有从dataCacheData的级联刷新。这样,您就可以完全控制刷新的内容和加载的内容。

答案 1 :(得分:0)

为什么不让对象更新域中的referenceCount,只要它触发数据库上的触发器以使其与持久值保持同步。