首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 其他教程 > 开源软件 >

mybatis 多线程环境下缓存有关问题

2013-10-28 
mybatis 多线程环境下缓存问题使用mybatis的都应该知道,mybatis是对select语句进行缓存的额,同一个select

mybatis 多线程环境下缓存问题

使用mybatis的都应该知道,mybatis是对select语句进行缓存的额,同一个select在一次sqlSession未被关闭之前是不会执行多次的(前提是对应的数据未被修改过,确切的说是未被当前sqlSession修改过),后面拿到的查询结果是第一次查询结果的缓存。

?

以上机制提升了效率,减少了与数据库通信的次数,这是mybatis的优点

?

但是如果你的应用处于多线程并发环境下,以上机制的问题就来了,独立线程一定使用各自独立的sqlSession,那么缓存的都是本线程下的查询过程,并发如果同同时修改一个资源(比如一个表的同一条记录)并且对后续select有影响的话,这个机制让你拿不到你想要的结果。

?

解决办法:

在后续select之前,执行sqlSession.clearCache();方法来清除缓存就可以了。

?

注:这个跟mybatis-config.xml和mapper.xm里的Cache不一样,需改配置文件解决不了这个问题,应该使用clearCache方法。

热点排行