`

Hibernate回调与拦截机制——Hibernate深入浅出

阅读更多
Hibernate的回调与拦截机制有三种实现方法:
1、实体对象implements Lifecycle接口,Lifecycle接口代码:
<!---->public interface Lifecycle {
    
/**
     * 在实体对象Save/Insert操作之前触发.
     
*/
    
public boolean onSave(Session s) throws CallbackException;
    
    
/**
     * 在Session.update()操作之前触发.
     
*/
    
public boolean onUpdate(Session s) throws CallbackException;

    
/**
     * 在实体对象删除之前触发.
     
*/
    
public boolean onDelete(Session s) throws CallbackException;

    
/**<!---->
     * 在实体对象加载之后触发.
     
*/
    
public void onLoad(Session s, Serializable id);
}
实体对象通过实现Lifecycle接口,即可以在特定的持久化阶段,触发特定的处理过程。比如在实体对象Tuser实现了Lifecycle接口的onSave方法,则在实体对象Tuser保存之前将先执行onSave方法。

2、实体对象implements Validatable接口,Validatable接口代码:
<!---->public interface Validatable {
    
public void validate() throws ValidationFailure;
}
   Validatable接口定义了数据验证实现方式。实体对象实现Validatable接口,并在validate方法中对当前待保存的数据进行验证,以保证数据的逻辑合法性(由于该方法在实体对象生命周期内,可能被多次调用,所以此方法最好只用于数据本身的逻辑合法性验证,而不要试图去实现数据业务逻辑的验证)。

以上2种方法都要求实现Hibernate中的Lifecycle或Validatable接口,具有很大的侵入性,使得实体对象的移植很不方便。Hibernate又提供了一种拦截机制,为对象持久化事件的捕获和处理提供了一个非侵入性的实现。

3、实现Interceptor接口,在创建session时,指定加载Interceptor相应的实现类,此session 的持久化操作都将首先经由此拦截器捕获处理。Interceptor(Hibernate3)接口代码:
<!---->package org.hibernate;

import java.io.Serializable;
import java.util.Iterator;

import org.hibernate.type.Type;

public interface Interceptor {
 
   
//对象初始化之前加载,这里的entity处于刚被创建的状态(即属性均未赋值).
    
public boolean onLoad(Object entity, Serializable id, Object[] state, String[] propertyNames,
            Type[] types) 
throws CallbackException;
   

    //Session.flush()方法进行脏数据检查时,如果发现PO状态改变,则调用此方法(即实体对象更新之前调用).
    public boolean onFlushDirty(Object entity, Serializable id, Object[] currentState,
           Object[] previousState, String[] propertyNames, Type[] types) 
throws CallbackException;
   
    //在实体对象被保存之前调用.
    
public boolean onSave(Object entity, Serializable id, Object[] state, String[] propertyNames,
           Type[] types) 
throws CallbackException;
   

    //在对象被删除之前调用.
    public void onDelete(Object entity, Serializable id, Object[] state, String[] propertyNames,
           Type[] types) 
throws CallbackException;
    
/**
     * Called before a collection is (re)created.
     
*/
    
public void onCollectionRecreate(Object collection, Serializable key) throws CallbackException;
    
/**
     * Called before a collection is deleted.
     
*/
    
public void onCollectionRemove(Object collection, Serializable key) throws CallbackException;
    
/**
     * Called before a collection is updated.
     
*/
    
public void onCollectionUpdate(Object collection, Serializable key) throws CallbackException;
   

    //Session执行flush方法之前调用.
    public void preFlush(Iterator entities) throws CallbackException;
  

    //Session执行flush方法之后调用.
    public void postFlush(Iterator entities) throws CallbackException;

    
/**
     * Called to distinguish between transient and detached entities. The return value determines the
     * state of the entity with respect to the current session.
     * <ul>
     * <li><tt>Boolean.TRUE</tt> - the entity is transient
     * <li><tt>Boolean.FALSE</tt> - the entity is detached
     * <li><tt>null</tt> - Hibernate uses the <tt>unsaved-value</tt> mapping and other heuristics to 
     * determine if the object is unsaved
     * </ul>
     * 
@param entity a transient or detached entity
     * 
@return Boolean or <tt>null</tt> to choose default behaviour
     
*/
    
public Boolean isTransient(Object entity);
    
/**
     * Called from <tt>flush()</tt>. The return value determines whether the entity is updated
     * <ul>
     * <li>an array of property indices - the entity is dirty
     * <li>an empty array - the entity is not dirty
     * <li><tt>null</tt> - use Hibernate's default dirty-checking algorithm
     * </ul>
     * 
@param entity a persistent entity
     * 
@return array of dirty property indices or <tt>null</tt> to choose default behaviour
     
*/
    
public int[] findDirty(Object entity, Serializable id, Object[] currentState,
             Object[] previousState, String[] propertyNames, Type[] types);
    
/**
     * Instantiate the entity class. Return <tt>null</tt> to indicate that Hibernate should use
     * the default constructor of the class. The identifier property of the returned instance
     * should be initialized with the given identifier.
     *
     * 
@param entityName the name of the entity
     * 
@param entityMode The type of entity instance to be returned.
     * 
@param id the identifier of the new instance
     * 
@return an instance of the class, or <tt>null</tt> to choose default behaviour
     
*/
    
public Object instantiate(String entityName, EntityMode entityMode,
           Serializable id) 
throws CallbackException;

    
/**
     * Get the entity name for a persistent or transient instance
     * 
@param object an entity instance
     * 
@return the name of the entity
     
*/
    
public String getEntityName(Object object) throws CallbackException;

    
/**
     * Get a fully loaded entity instance that is cached externally
     * 
@param entityName the name of the entity
     * 
@param id the instance identifier
     * 
@return a fully initialized entity
     * 
@throws CallbackException
     
*/
    
public Object getEntity(String entityName, Serializable id) throws CallbackException;
    
    
/**
     * Called when a Hibernate transaction is begun via the Hibernate <tt>Transaction</tt> 
     * API. Will not be called if transactions are being controlled via some other 
     * mechanism (CMT, for example).
     
*/
    
public void afterTransactionBegin(Transaction tx);
    
/**
     * Called before a transaction is committed (but not before rollback).
     
*/
    
public void beforeTransactionCompletion(Transaction tx);
    
/**     * Called after a transaction is committed or rolled back.
     
*/
    
public void afterTransactionCompletion(Transaction tx);

    
/**
     * Called when sql string is being prepared. 
     * 
@param sql sql to be prepared
     * 
@return original or modified sql
     
*/
    
public String onPrepareStatement(String sql);
}




分享到:
评论
2 楼 friping 2009-10-20  
不好意思,刚刚不小心点了提交。发错了
1 楼 friping 2009-10-20  
   表格: 用换行和
来编辑格子
:sh
字体颜色: 标准深红红色橙色棕色黄色绿色橄榄青色蓝色深蓝靛蓝紫色灰色白色黑色 字体大小: 标准1 (xx-small)2 (x-small)3 (small)4 (medium)5 (large)6 (x-large)7 (xx-large) 对齐: 标准居左居中居右
插入表格: 用换行和
来编辑格子
ock:  

相关推荐

    深入浅出Hibernate(PDF)第二部分

    本书内容深入浅出,先讲述持久层设计与ORM,再由Hibernate概述、Hibernate基础Hibernate高级特性顺序展开,直至Hibernate实战,重点讲述了Hibernate的基础语法、基础配置、O/R映射、数据关联、数据检索、HQL实用技术...

    深入浅出hibernate(PDF)第三部分

    本书内容深入浅出,先讲述持久层设计与ORM,再由Hibernate概述、Hibernate基础Hibernate高级特性顺序展开,直至Hibernate实战,重点讲述了Hibernate的基础语法、基础配置、O/R映射、数据关联、数据检索、HQL实用技术...

    深入浅出Hibernate中文版 part1

    5.2 Hibernate回调与拦截机制 5.3 Hibernate实用技术 第6章 Hibernate 实战——创建RedSaga论坛 6.1 目标 6.2 E-R建模还是对象建模 6.3 E-R建模及工具集 6.4 对象建模 6.5 项目的目录组织和基础设施 6.6 测试...

    深入浅出Hibernate

    本书内容深入浅出,先讲述持久层设计与ORM,再由Hibernate概述、Hibernate基础Hibernate高级特性顺序展开,直至Hibernate实战,重点讲述了 Hibernate的基础语法、基础配置、O/R映射、数据关联、数据检索、HQL实用...

    深入浅出Hibernate(PDF)第一部分

    本书内容深入浅出,先讲述持久层设计与ORM,再由Hibernate概述、Hibernate基础Hibernate高级特性顺序展开,直至Hibernate实战,重点讲述了Hibernate的基础语法、基础配置、O/R映射、数据关联、数据检索、HQL实用技术...

    夏昕.深入浅出Hibernate

    本书内容深入浅出,先讲述持久层设计与ORM,再由Hibernate概述、Hibernate基础Hibernate高级特性顺序展开,直至Hibernate实战,重点讲述了 Hibernate的基础语法、基础配置、O/R映射、数据关联、数据检索、HQL实用...

    \深入浅出Hibernate

    本书内容深入浅出,先讲述持久层设计与ORM,再由Hibernate概述、Hibernate基础Hibernate高级特性顺序展开,直至Hibernate实战,重点讲述了Hibernate的基础语法、基础配置、O/R映射、数据关联、数据检索、HQL实用技术...

    深入浅出Hibernate2

    本书内容深入浅出,先讲述持久层设计与ORM,再由Hibernate概述、Hibernate基础Hibernate高级特性顺序展开,直至Hibernate实战,重点讲述了Hibernate的基础语法、基础配置、O/R映射、数据关联、数据检索、HQL实用技术...

    中文 深入浅出Hibernate

    本书内容深入浅出,先讲述持久层设计与ORM,再由Hibernate概述、Hibernate基础Hibernate高级特性顺序展开,直至Hibernate实战,重点讲述了Hibernate的基础语法、基础配置、O/R映射、数据关联、数据检索、HQL实用技术...

    《深入浅出Hibernate》1

    本书内容深入浅出,先讲述持久层设计与ORM,再由Hibernate概述、Hibernate基础Hibernate高级特性顺序展开,直至Hibernate实战,重点讲述了Hibernate的基础语法、基础配置、O/R映射、数据关联、数据检索、HQL实用技术...

    深入浅出Hibernate中文版 part2

    5.2 Hibernate回调与拦截机制 5.3 Hibernate实用技术 第6章 Hibernate 实战——创建RedSaga论坛 6.1 目标 6.2 E-R建模还是对象建模 6.3 E-R建模及工具集 6.4 对象建模 6.5 项目的目录组织和基础设施 6.6 测试...

    Hibernate的高级操作[归纳].pdf

    在本章中,我们将深入探讨Hibernate的高级特性,特别是关于对象的持久化实现和回调与拦截机制。首先,让我们详细解析Hibernate的实体对象生命周期。 在Hibernate中,实体对象经历了三种不同的状态,它们分别是: 1...

    hibernate教程hibernate教程

    Hibernate提供了回调和拦截机制,允许在特定事件(如对象保存、更新、删除等)前后执行自定义代码。这在数据同步、日志记录或其他业务逻辑处理中非常有用。 **配置二级缓存** 配置二级缓存需要指定缓存策略(如read...

    Hibernate的高级操作

    #### Hibernate回调与拦截机制 Hibernate提供了一套强大的事件监听系统,允许开发者在特定时刻执行自定义逻辑。这包括但不限于实体的创建、更新、删除等生命周期事件。 - **Lifecycle与Validatable接口**:`...

    hibernate4.jar

    9. **事件监听器和拦截器**:Hibernate允许开发者注册事件监听器和拦截器,对持久化操作进行自定义处理,如在对象保存前后的回调函数。 10. **多数据源支持**:通过SessionFactoryBuilder,Hibernate可以配置多个...

    hibernate最新版本5.2.3所有jar包

    - Hibernate提供了对JPA规范的扩展,如`@PrePersist`、`@PostLoad`等回调注解,增强了实体的生命周期管理。 10. **性能优化**: - Hibernate提供了各种性能调优选项,包括批处理、延迟加载、懒加载等策略,以适应...

Global site tag (gtag.js) - Google Analytics