mysql withur报错_DB2使用Hibernate拦截器实现脏读(withur)

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

工作需要,最近要让开发的系统底层适应的数据库增加对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数据库时,能够进行脏读操作。

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值