0

假设我有两个类FooBarFoo与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插入语句,但是对实体对象执行了SQL更新语句,实体对象是Foo,并且在插入之前被修改了。这会导致以下 Hibernate 异常。

最后一个原因:批量更新从更新[0]返回了意外的行数;实际行数:0;预期:1

如果我不保存 bar 对象,则会按预期执行 SQL 插入语句。

关于可能出了什么问题的任何见解?

提前致谢。

4

1 回答 1

0

我认为您需要在拦截器的onFlushDirty方法中对currentState数组进行更新。

有一个类似的问题,因为我正在修改onLoadonFlushDirty方法中的对象。问题是休眠认为对象的先前状态是由onLoad方法产生的状态,并且更新语句试图使用这些值来查找 db 表中的行。可能是同样的问题,因为您正在修改onSave方法中的状态。

于 2013-06-06T15:47:25.447 回答