一、缓存机制
缓存机制可以减轻数据库的压力,原理是在第一查询时,将查询结果缓存起来,之后再查询同样的sql,不是真的去查询数据库,而是直接返回缓存中的结果。缓存可以降低数据库的压力,但同时可能无法得到最新的结果数据。在Mybatis框架中,为我们设提供了两种缓存机制。一个是一级缓存,另一个是二级缓存。一级缓存是默认开启的。
二、一级缓存
Mybatis的一级缓存,只在一个事务中有效,即同一个事务中先后执行多次同一个查询,只在第一次真正去查库,并将结果缓存,之后的查询都直接获取缓存中的中数据。如果是不同的事务,则缓存是隔离的,还是要去查询的。
Mybatis的一级缓存,默认是开启的,而且无法手动关闭。
三、二级缓存
二级缓存,在全局有效,一个事务查询一个sql得到结果,会被缓存起来,之后只要缓存未被清除,则其他事务如果查询同一个sql,得到的将会是之前缓存的结果。
二级缓存作用范围大,作用时间长,可能造成的危害也更大,所以在开发中一般很少启用Mybatis的二级缓存。
开启二级缓存
【1】首先,在sqlMapperConfig.xml配置文件中,配置setting标签,将之放置在所有配置的最前面。
<settings>
<setting name="cacheEnabled" value="true"/>
</settings>
【2】在需要二级缓存的,映射文件中书写<cache/>,表示该映射文件中,所有操作,将执行二级缓存机制。
<cache/>
【3】使用二级缓存的bean,必须实现serializable接口