使用Redis做MyBatis的二级缓存
目录
1、什么是Redis二级缓存
2、需求
3、步骤分析与实战(具体事例)
4、测试
5、总结
什么是Redis二级缓存
Redis的二级缓存就是:控制器第一次查询是Mybatis对数据库进行查询,从数据库查询到的数据通过配置文件与RedisCache类将数据缓存到Redis中,当需要第二次查询相同数据时,就会从Redis中取出缓存的内容,而不会查询数据库,减轻了数据库的压力,查询更迅速。当提交修改此条数据的内容的代码时,会执行commit操作,Redis就会清空之前缓存的数据,而缓存修改后的最新的数据,此时显示页面不管怎么刷新,都是去Redis中取出缓存的最新数据。
需求
第一次根据用户姓名查询用户信息
select * from user where username=?
分析:
第一次根据用户姓名查询用户信息,根据控制台的日志,查看数据库执行操作步骤。
第二次根据姓名查询同一个用户信息
select * from user where username=?
分析:
第二次根据用户姓名查询用户信息,根据控制台的日志,查看数据库执行操作步骤。
步骤分析
①、需要配置好SSM的开发环境,导包,下面是redis需要的包
②、在Mybatis的配置文件中开启缓存设置
代码:
<settings>
<!-- 全局映射器启用缓存 *主要将此属性设置完成即可 -->
<setting name="cacheEnabled" value="true" />
<!-- 查询时,关闭关联对象即时加载以提高性能 -->
<setting name="lazyLoadingEnabled" value="false" />
<!-- 设置关联对象加载的形态,此处为按需加载字段(加载字段由SQL指 定),不会加载关联表的所有字段,以提高性能 -->
<setting name="aggressiveLazyLoading" value="true" />
</settings>
③、配置Redis配置文件
④、spring配置文件applicationContext.xml中加载redis.properties配置文件
代码:
<context:property-placeholder location="classpath:redis.properties" ignore-unresolvable="true"/>
<!-- redis数据源 -->
<bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig">
<property name="maxIdle" value="${redis.maxIdle}" />
<property name="maxTotal" value="${redis.maxActive}" />
<property name="maxWaitMillis" value="${redis.maxWait}" />
<property name="testOnBorrow" value="true"></pr