MyBatis 二级缓存


    /**
     * 测试二级缓存,
     * 二级缓存默认是关闭的,如果想使用二级缓存需要做如下两边操作:
     * 1.开启二级缓存的总开关(在mybatis的配置文件中设置),这步可以不做,因为默认就开启的
     *  <!-- 
     *      A:开启二级缓存的总开关,由于默认值就是true,所以可以不配
     * 注意:如果同时设置了settings和typeAliases则要求settings必须设置在typeAliases的前面,否则违背了dtd约束报错。
     *  -->
        <settings>
            <setting name="cacheEnabled" value="true"/>
        </settings>

        2.开启指定mapper下的二级缓存(在mybatis的映射文件中设置)
            <!-- B:开启当前mapper下的二级缓存 -->
            <cache/>

     * 
     * 注意点:
     *  A:只有在将第一次查询时使用的sqlSession提交后才会将查找到的对象存入到二级缓存中,否则不会自动存入。
     *  B:如果想将查询到的对象存入到二级缓存中,则必须让当前对象的类实现Serializable接口,否则报异常:
     *      Cause: org.apache.ibatis.cache.CacheException: Error serializing object.  
     *      Cause: java.io.NotSerializableException: com.hsj.domain.Worker
     */
    @Test
    public void testGetWorkerByIdWithSecondCache() {
        int id=1;
        try {
            SqlSession sqlSession1=MyBatisUtils.getSqlSession();
            SqlSession sqlSession2=MyBatisUtils.getSqlSession();

            //1.从数据库中查询信息并存入到一级缓存中
            Worker worker1=sqlSession1.selectOne("com.hsj.dao.WorkerDao.getWorkerByIdWithSecondCache", id);
            System.out.println("worker1="+worker1);
            //2.如果想把查询的对象存入到二级缓存中,则必须调用当前sqlSession的commit()方法,否则不会将查询到的对象写入到二级缓存中
            sqlSession1.commit();
            System.out.println("=================");
            Worker worker2=sqlSession2.selectOne("com.hsj.dao.WorkerDao.getWorkerByIdWithSecondCache", id);
            System.out.println("worker2="+worker2);
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
 PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
 "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.hsj.dao.WorkerDao">

    <!-- 
    B:开启当前mapper下的二级缓存
        eviction="FIFO":设置缓存淘汰对象的策略,
            FIFO(First In First Out):按照对象进入缓存的时间顺序决定淘汰顺序
            LRU(Least Recently Used):最近最少使用算法
            LFU(Least Frequence Used):使用频率最少的对象优先从缓存中清除的算法。

        flushInterval="60000":每隔多少毫秒扫描一次缓存对象
        size="512":缓存中最大可以缓存的对象数目
        readOnly="true":缓存对象是只读的

     -->
    <cache
        eviction="FIFO"
        flushInterval="60000"
        size="512"
        readOnly="true"
    />


    ........

</mapper>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值