设为首页 加入收藏

TOP

DB2使用Hibernate拦截器实现脏读(withur)
2015-07-24 11:21:00 来源: 作者: 【 】 浏览:3
Tags:DB2 使用 Hibernate 拦截 实现 withur

工作需要,最近要让开发的系统底层适应的数据库增加对DB2的支持,虽然使用了DB2,但是就性能考虑,和业务需要。查询不需要进行事务控制,也就是DB2的多种事务安全级别,在查询时,不需要关注更新和插入。因此需要查询支持脏读。每条查询的sql语句后面都要增加with ur选项。

在网上找了很久,很多人在问,但是没有结果。最后,在google找到解决办法,使用hibernate拦截器,进行拦截。下面是代码:

import org.hibernate.EmptyInterceptor;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * hibernate配置DB2时,为了防止高事务安全级别对查询造成影响,因此查询需要单独制定with ur。
 * 此类是hibernate拦截器,用于给select的查询末尾增加with ur选项,以防止查询时锁住数据库库。
 * @author superxb
 * 
 */
public class DB2Interceptor extends EmptyInterceptor {
	private static final long serialVersionUID = 1L;

	private static final Logger logger = LoggerFactory
			.getLogger(DB2Interceptor.class);

	@Override
	public String onPrepareStatement(String str) {

		// sql字符串全部转换成小写
		String compstr = str.toLowerCase();

		// 所有的select语句,只要是不包含with ur的。在后面都加上with ur
		if (compstr.matches("^select.*") && !compstr.matches(".*for update.*")) {
			if (!compstr.matches(".*with ur.*")) {
				str += " with ur ";
				logger.debug("Appending \"WITH UR\" to query.");
			}
		}
		return str;
	}
}

拦截器创建好后,配置在hibernate的sessionFactory即可。配置参考如下:

	
		
			
		
		
		
			
		
……
……
如上配置之后。默认的,只要是select开头的sql语句,其中未包含with ur的话,就会在末尾增加with ur,以确保事务安全级别,实现hibernate映射DB2数据库时,能够进行脏读操作。
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇关于db2的一点记录 下一篇数据泵expdp,impdp使用结

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·如何在 C 语言中管理 (2025-12-25 03:20:14)
·C语言和内存管理有什 (2025-12-25 03:20:11)
·为什么C语言从不被淘 (2025-12-25 03:20:08)
·常用meta整理 | 菜鸟 (2025-12-25 01:21:52)
·SQL HAVING 子句:深 (2025-12-25 01:21:47)