首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

利用Hibernate Interceptor回调机制 一致设置数据表的共通属性

2012-10-15 
利用Hibernate Interceptor回调机制 统一设置数据表的共通属性Hibernate给我们提供了非常灵活的机制,可以

利用Hibernate Interceptor回调机制 统一设置数据表的共通属性
Hibernate给我们提供了非常灵活的机制,可以让我们非常容易地做一些共通处理,比如所有表都有同样的字段,可以用同样的方法设值。这时我们没必要在业务处理中每个地方都写上同样的代码。

例如:我们几乎所有的表中都有2个字段:UPDATE_DATETIME和CREATE_DATETIME。分别对应属性名为:updateDatetime和createDatetime。我们需要在修改数据时自动设置updateDatetime,插入数据时自动设置updateDatetime,createDatetime。

我们可以利用Hibernate提供给我们的Interceptor机制实现这个目标。

实现方法:
首先写一个类继承org.hibernate.EmptyInterceptor或者实现org.hibernate.Interceptor接口:
为了简单起见,一般直接继承org.hibernate.EmptyInterceptor就可以了。
然后重载一下onFlushDirty方法和onSave方法就可以了。

因为Hibernate会在更新数据时回调onFlushDirty方法,在插入数据时回调onSave方法。

例:

public class MyHibernateInterceptor extends EmptyInterceptor {   
    public boolean onFlushDirty(Object entity, Serializable id,   
            Object[] currentState, Object[] previousState,   
            String[] propertyNames, Type[] types) throws CallbackException {   
        try {   
               
            Date updtime = new Date();   
               
            for (int i = 0; i < propertyNames.length; i++) {   
                if ("updateDatetime".equals(propertyNames[i])) {   
                    state[i] = updtime;   
                }   
            }   
        } catch (Exception ex) {   
            return false;   
        }   
  
        return true;   
    }   
       
    public boolean onSave(Object entity, Serializable id, Object[] state,   
            String[] propertyNames, Type[] types) throws CallbackException {   
        try {   
               
            Date updtime = new Date();   
               
            for (int i = 0; i < propertyNames.length; i++) {   
                if ("updateDatetime".equals(propertyNames[i])   
                        || "createDatetime".equals(propertyNames[i])) {   
                    state[i] = updtime;   
                }   
            }   
        } catch (Exception ex) {   
            return false;   
        }   
  
        return true;   
    }   
}  
public class MyHibernateInterceptor extends EmptyInterceptor {
    public boolean onFlushDirty(Object entity, Serializable id,
            Object[] currentState, Object[] previousState,
            String[] propertyNames, Type[] types) throws CallbackException {
        try {
           
            Date updtime = new Date();
           
            for (int i = 0; i < propertyNames.length; i++) {
                if ("updateDatetime".equals(propertyNames[i])) {
                    state[i] = updtime;
                }
            }
        } catch (Exception ex) {
            return false;
        }

        return true;
    }
   
    public boolean onSave(Object entity, Serializable id, Object[] state,
            String[] propertyNames, Type[] types) throws CallbackException {
        try {
           
            Date updtime = new Date();
           
            for (int i = 0; i < propertyNames.length; i++) {
                if ("updateDatetime".equals(propertyNames[i])
                        || "createDatetime".equals(propertyNames[i])) {
                    state[i] = updtime;
                }
            }
        } catch (Exception ex) {
            return false;
        }

        return true;
    }
}

为了使Hibernate能回调我们的方法,需要在open session时设置:
Session session = SessionFactory.openSession(new MyHibernateInterceptor());

测试代码这里就不介绍了。可以自己写个数据插入/修改的TestCase,看看数据库那2个字段是否被正确地设置了日期。

热点排行