缓存?缓存的作用的是是什么?缓存其实在我们编程过程中无处不在,不要多想他的其他功能,因为它唯一功能,也是设计初衷就是为了速度快,提升响应速度。

今天我们来聊聊的缓存,它分为一级缓存和二级缓存。说白了也是为了快才设计,这一点很重要,看完文章后大脑中在想一遍,为什么这样设计,为了快!

在我们的Web盛起的今天,我们所有的操作都是对数据库(例如Mysql)的增删改查,我们的查询操作是最多的,其实我们请求一个查询接口的时候,直到服务器给我响应数据,这一过程中最耗时的就是我们程序对数据库建立起连接,查询数据的这一环节。但如果用户想要某个数据时每次都去数据库查询,这无疑会增加数据库的压力,而且获取时间效率也会降低,所以为了解决这些问题,缓存应用而生,使用了缓存之后mybatis一级缓存和二级缓存,服务器只需要查询一次数据库,然后将数据保存到服务器主机的内存中,以后读取时就直接取内存中的数据,而不需要每次都查数据库,这种方案除了降低数据库压力之外mybatis一级缓存和二级缓存,还提高了响应速度。

的一级缓存是默认开启的,它在一个会话里面的所有查询操作都会保存到缓存中,一般来说一个请求中的所有增删改查操作都是在同一个里面的,所以我们可以认为每个请求都有自己的一级缓存,如果同一个会话中2 个查询中间有一个 、或 语句,那么之前查询的所有缓存都会清空。

Reader reader = Resources.getResourceAsReader("config/configuration.xml");
//创建数据工厂
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
SqlSessionFactory sqlSessionFactory = builder.build(reader);
SqlSession sqlSession = sqlSessionFactory.openSession(true);
// 。。。。。。 
// 这中间所走的所有查询操作都会进行缓存,一旦关闭sqlSession会话,缓存则会刷新
//释放会话
sqlSession.clearCache();
// 关闭会话
sqlSession.close();

在 的配置文件中加入以下配置,开启sql日志,每一个sql代表请求了一次数据库,这样我们就可以根据sql来判断是否使用了缓存。


        
        
    

public static void main(String[] args) throws IOException {
        // 加载mybatis配置文件
        Reader reader = Resources.getResourceAsReader("config/configuration.xml");
        //创建数据工厂
        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
        SqlSessionFactory sqlSessionFactory = builder.build(reader);
        SqlSession sqlSession = sqlSessionFactory.openSession(true);
        // 获取mapper接口对象
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        // 查询第一次
        User user = mapper.selectByPrimaryKey("3rfrf34r34");
        // 第二次查询
        User user1 = mapper.selectByPrimaryKey("3rfrf34r34");
        System.out.println("两个user对象是否相等:"+(user == user1));
        //释放会话
        sqlSession.clearCache();
        sqlSession.close();
    }

根据结果可以看到,代码中执行了2次查询, 但实际运行时只查询了一次数据库,第二次获取数据时直接从缓存中读取,并且2次读取的数据都是一样的,到这里,一级缓存就已经生效了;

接下来我们来测试第二种情况 :查询 -> 修改 -> 查询

public static void main(String[] args) throws IOException {
        // 加载mybatis配置文件
        Reader reader = Resources.getResourceAsReader("config/configuration.xml");
        //创建数据工厂
        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
        SqlSessionFactory sqlSessionFactory = builder.build(reader);
        SqlSession sqlSession = sqlSessionFactory.openSession(true);
        // 获取mapper接口对象
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        // 查询第一次
        User user = mapper.selectByPrimaryKey("3rfrf34r34");
        // 修改
        mapper.updateByPrimaryKey(user);
        // 第二次查询
        User user1 = mapper.selectByPrimaryKey("3rfrf34r34");
        System.out.println("两个user对象是否相等:"+(user == user1));
        //释放会话
        sqlSession.clearCache();
        sqlSession.close();
    }

控制台打印了三次sql,其中第一个查询和第三个查询是一样的,但是并没有使用缓存,为什么会这样呢?因为每次增删改操作都有可能会改变原来的数据,所以必须刷新缓存;

的二级缓存

二级缓存是全局的,也就是说;多个请求可以共用一个缓存,二级缓存需要手动开启,有2种方式配置二级缓存。

第一种配置方式:

单个配置,主需要在需要开启二级缓存的.xml文件中加入以下配置即可开启

 
  

第二种配置方式:

所有的都开启二级缓存,在.xml中加入以下配置即可


        
        
    

这样当我们使用两个会话,第一个使用完关闭,第二个使用查询的时候仍然去缓存种查询,这样就走了二级缓存,当然得保证缓存种有这条查询(查询sql一样才行)

总结:了解一下设计过程就可以,设计缓存最终目的就是为了快,减少和数据库打交道。这也是我们优化程序的时候最应该首先想到的

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注