假设我有两个类 Foo 和 Bar 。 Foo 与 Bar 的多对一关联映射如下:
<many-to-one name="bar" class="Bar" lazy="false" fetch="join" >
<column name="BAR_ID" sql-type="INTEGER" />
</many-to-one>
我创建了一个自定义拦截器,它从 EmptyInterceptor 扩展并覆盖 onSave 方法,如下所示:
public boolean onSave(Object entity, Serializable id, Object[] state,
String[] propertyNames, Type[] types) {
boolean modified = false;
if(entity instanceof Foo) {
Bar bar = new Bar();
//do some initialization stuff to bar
for(int i = 0; i < propertyNames.length; i++) {
if("bar".equals(propertyNames[i])) {
state[i] = bar;
modified = true;
break;
}
}
//This code essentially gets the current hibernate session and calls save on
//the passed object.
BarDAO barDao = BarDAO.INSTANCE;
barDAO.save(bar);
}
return modified;
}
问题是虽然为bar执行了SQL insert语句,但是为实体对象执行了SQL更新语句,这是一个Foo并在插入之前被修改。这会导致以下Hibernate异常。
最后一个原因:批量更新从更新返回了意外的行数 [0];实际行数:0;预期:1
如果我不保存bar对象,则会按预期执行SQL insert语句。
对可能出现的问题有任何见解?
提前致谢。
答案 0 :(得分:0)
我认为您需要对拦截器中 onFlushDirty 方法中的 currentState 数组进行更新。
有一个类似的问题,因为我正在修改 onLoad 和 onFlushDirty 方法中的对象。问题是hibernate认为对象的先前状态是由 onLoad 方法产生的状态,并且update语句试图使用这些值来查找db表中的行。可能是同一个问题,因为您正在 onSave 方法中修改状态。