Mybatis中的缓存

Mybatis中的缓存

什么是缓存

存在于内存中的临时数据。

为什么使用缓存

减少和数据库的交互次数,提高执行效率。

什么样的数据能使用缓存,什么样的数据不能使用

  • 适用于缓存:
    1. 经常查询并且不经常改变的。
    2. 数据的正确与否对最终结果影响不大的。
  • 不适用于缓存:
    1. 经常经常改变的数据。
    2. 数据的正确与否对最终结果影响很大的。
    3. 例如:商品的库存,银行的汇率,股市的牌价。

Mybatis中的一级缓存和二级缓存

  • 一级缓存:
    1. 它指的是Mybatis中SqlSession对象的缓存。
    2. 当我们执行查询之后,查询的结果会同时存入到SqlSession为我们提供一块区域中。
    3. 该区域的结构是一个Map。当我们再次查询同样的数据,mybatis会先去sqlsession中,查询是否有,有的话直接拿出来用。
    4. 当SqlSession对象消失时,mybatis的一级缓存也就消失了。
  • 二级缓存:
    1. 它指的是Mybatis中SqlSessionFactory对象的缓存。
    2. 由同一个SqlSessionFactory对象创建的SqlSession共享其缓存。
    3. 二级缓存的使用步骤:
      1. 让Mybatis框架支持二级缓存(在SqlMapConfig.xml中配置)
      2. 让当前的映射文件支持二级缓存(在IUserDao.xml中配置)
      3. 让当前的操作支持二级缓存(在select标签中配置)

缓存示例

`
/** * 测试一级缓存 */
@Test
public void TestAll()
{
        User user = iUserDao.findById(42);    
        System.out.println(user);    
        User user1 = iUserDao.findById(42);    
        System.out.println(user1);
}
输出结果
com.itheima.domain.User@4d02f94e
com.itheima.domain.User@4d02f94e

/** 
* 测试一级缓存 
*/
@Test
public void TestAll()
{    
        User user = iUserDao.findById(42);    
        System.out.println(user);    
        sqlSession.close();    
        sqlSession= MyBaitsUtil.getSession();    
        iUserDao= sqlSession.getMapper(IUserDao.class);    
        User user1 = iUserDao.findById(42);    
        System.out.println(user1);
}

输出结果
com.itheima.domain.User@4d02f94e
com.itheima.domain.User@1e683a3e

/** * 测试二级缓存 */
全局配置
    <settings><setting name="cacheEnabled" value="true"/></settings>
    相应的xml配置
    <cache/>
    <!-- 查询所有 --><select id="findAll" resultType="user" 
    useCache="true">    select * from user u</select>

@Test
public void TestAll()
{    
        SqlSession sqlSession1 = MyBaitsUtil.getSession();    
        IUserDao dao1= sqlSession1.getMapper(IUserDao.class);    
        User user = dao1.findById(42);    
        System.out.println(user);      
        sqlSession1.close();//一级缓存消失    
        SqlSession sqlSession2 = MyBaitsUtil.getSession();    
        IUserDao dao2= sqlSession2.getMapper(IUserDao.class);    
        User user1 = dao2.findById(42);    
        System.out.println(user1);
}

输出结果
2019-07-17 10:27:28,023 612    [main] DEBUG ansaction.jdbc.JdbcTransaction  - Setting autocommit to false on JDBC Connection [com.mysql.cj.jdbc.ConnectionImpl@55536d9e]
2019-07-17 10:27:28,029 618    [main] DEBUG .itheima.dao.IUserDao.findById  - ==>  Preparing: select * from user where id = ? 
2019-07-17 10:27:28,085 674    [main] DEBUG .itheima.dao.IUserDao.findById  - ==> Parameters: 42(Integer)
2019-07-17 10:27:28,120 709    [main] DEBUG .itheima.dao.IUserDao.findById  - <==      Total: 1
com.itheima.domain.User@fba92d3
2019-07-17 10:27:28,132 721    [main] DEBUG ansaction.jdbc.JdbcTransaction  - Resetting autocommit to true on JDBC Connection [com.mysql.cj.jdbc.ConnectionImpl@55536d9e]
2019-07-17 10:27:28,132 721    [main] DEBUG ansaction.jdbc.JdbcTransaction  - Closing JDBC Connection [com.mysql.cj.jdbc.ConnectionImpl@55536d9e]
2019-07-17 10:27:28,132 721    [main] DEBUG source.pooled.PooledDataSource  - Returned connection 1431530910 to pool.
2019-07-17 10:27:28,136 725    [main] DEBUG       com.itheima.dao.IUserDao  - Cache Hit Ratio [com.itheima.dao.IUserDao]: 0.5
com.itheima.domain.User@2b91004a
`
posted on 2019-07-17 10:35  杨伟国  阅读(286)  评论(0编辑  收藏  举报