mybatis 多线程环境下缓存问题
使用mybatis的都应该知道,mybatis是对select语句进行缓存的额,同一个select在一次sqlSession未被关闭之前是不会执行多次的(前提是对应的数据未被修改过,确切的说是未被当前sqlSession修改过),后面拿到的查询结果是第一次查询结果的缓存。
?
以上机制提升了效率,减少了与数据库通信的次数,这是mybatis的优点
?
但是如果你的应用处于多线程并发环境下,以上机制的问题就来了,独立线程一定使用各自独立的sqlSession,那么缓存的都是本线程下的查询过程,并发如果同同时修改一个资源(比如一个表的同一条记录)并且对后续select有影响的话,这个机制让你拿不到你想要的结果。
?
解决办法:
在后续select之前,执行sqlSession.clearCache();方法来清除缓存就可以了。
?
注:这个跟mybatis-config.xml和mapper.xm里的Cache不一样,需改配置文件解决不了这个问题,应该使用clearCache方法。