Hibernate如何实现拦截器与监听器
这篇文章将为大家详细讲解有关Hibernate如何实现拦截器与监听器,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
拦截器与事件都是Hibernate的扩展机制,Interceptor接口是老的实现机制,现在改成事件监听机制;他们都是Hibernate的回调接口,Hibernate在调用save、delete、update...这些方法的时候会回调这个类。
Hibernate3.0之前拦截器跟java中的过滤器很像的。
Hibernate3.0之后把拦截器改成事件监听了。
saveOrUpdateEventListener接口:
保存和更新数据的时候会被Hibernate监听到。
例子:
if(event.getObject() instanceof com.cos.User){
//如果这个事件是操作User对象的,就执行if里面的代码
}
把监听器告诉Hibernate:
监听器SaveListener.java:
Java代码
package com.cos.listener; import org.hibernate.HibernateException; import org.hibernate.event.SaveOrUpdateEvent; import org.hibernate.event.SaveOrUpdateEventListener; public class SaveListener implements SaveOrUpdateEventListener { @Override public void onSaveOrUpdate(SaveOrUpdateEvent event) throws HibernateException { if(event.getObject() instanceof com.cos.entity.User){ System.out.println("保存User之前的操作"); } } }
Hibernate配置文件:
Xml代码
"-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> <hibernate-configuration> <session-factory> <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialectproperty> <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driverproperty> <property name="hibernate.connection.url">jdbc:mysql:///testproperty> <property name="hibernate.connection.username">property> <property name="hibernate.connection.password">property> <property name="hibernate.show_sql">trueproperty> <property name="hibernate.hbm2ddl.auto">createproperty> <mapping resource="com/cos/entity/User.hbm.xml"/> <event type="save"> <listener class="com.cos.listener.SaveListener"/> <listener class="org.hibernate.event.def.DefaultSaveOrUpdateEventListener"/> event> session-factory> hibernate-configuration>
可以看到两个监听器,一个是自己的监听器、一个是缺省的监听器。两个监听器哪个在前就先执行哪个监听器。
关于“Hibernate如何实现拦截器与监听器”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:niceseo99@gmail.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。版权声明:如无特殊标注,文章均为本站原创,转载时请以链接形式注明文章出处。
评论