还是Hibernate,用了以前的代码,在实体 update 之前,使用 PreUpdateEventListener,
对实体当中的 lastModified 属性进行设置。这样,只要实体有 lastModified 属性,这个listener
就会自动的将它的最后更新时间给设置为最新的。
public boolean onPreUpdate( PreUpdateEvent event) { try { Object entity = event.getEntity(); Method method = entity.getClass().getMethod( "setLastModified", Date.class); if ( method != null) method.invoke( entity, new Date()); } catch ( Exception e) { } }
话说这段代码也是很早以前写的,一直都没啥问题。
最近放到一个新项目当中,问题出来了。lastModified字段就一直没啥变化。
跟踪了一下,发现实体当中的lastModified字段确实改过来了,但是因为hibernate
做dirtyCheck之后,才会调用 preUpdate方法。也就是说,这个时候,光改 entity
的属性是不够的,还要想办法去改它的state,然后hibernate才会发现这个值已经发生了
变化。这个大概是因为dirtyCheck成本较高的缘故所发生的一个变化。于是代码改成:
public boolean onPreUpdate( PreUpdateEvent event) { try { Date date = new Date(); Object entity = event.getEntity(); Method method = entity.getClass().getMethod( "setLastModified", Date.class); if ( method != null) method.invoke( entity, date); String[] names = event.getPersisteer().getPropertyNames(); for ( int i=0; i<names.length; i++) { if ( "lastModified".equals( names[i])) { event.getState()[i] = date; break; } } } catch ( Exception e) { } }
果然是世界变化快啊。