Mybatis的一级缓存默认是开启的,并且其作用域有两个级别 SESSION和STAMENT
默认为SESSION级别(Confugration中默认定义),对应存储的对象为PerpetualCache.
Mybatis在执行查询时,会对执行的Sql生成一个缓存Key,该缓存Key是由MapperedStament的ID,SQL语句以及参数还有哈希值所构成.
根据生成的Key到缓存中去取,缓存中存在直接返回,不存在查询数据库
另外,如若想关闭一级缓存在配置中将localCacheScope设置为STAMENT即可。因为当作用域为STATEMENT时会清空缓存:
还有当Mybatis执行增删改时会首先清除一级缓存,避免缓存中数据与数据库不一致:
尽管如此,Mybatis的一级缓存还是可能会出现脏读:
比如两个sqlsession1,sqlsession2
1先执行了查询,将执行结果缓存下来,2执行了修改,这个时候因为1和2是不同sqlsession所以这个时候1再执行同样的查询会从之前缓存中去取,这就导致了实际数据不一致的情况。所以建议整合Spring来使用。



