赞
踩
MyBatis一级缓存的作用域是同一个SqlSession,在同一个SqlSession中执行两次相同的查询,第一次执行完毕后,Mybatis会将查询到的数据缓存起来(缓存到内存中), 第二次执行相同的查询时,会从缓存中取数据,不再进行数据库的查询,从而提高查询效率。默认情况下,Mybatis开启了一级缓存。但是MyBatis整合Spring Boot时,一级缓存却没有生效。
- /**
- * 验证MyBatis的一级缓存默认是开启的
- */
- @Test
- public void getUserByIdTest() {
- UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
-
- UserDO userDO1 = userMapper.getUserById(1L);
- System.out.println("userDO1 = " + userDO1);
-
- System.out.println("====================");
-
- UserDO userDO2 = userMapper.getUserById(1L);
- System.out.println("userDO2 = " + userDO2);
- }
当同一个线程开启事务时,同一个sql查询多次会走一级缓存,而不开启事务时,每一查询都是不同的sqlsession,即缓存为“失效”状态 。
添加 @Transactional 注解。
- /**
- * 验证MyBatis的一级缓存默认是开启的
- */
- @Transactional
- @Test
- public void getUserByIdTest() {
- UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
-
- UserDO userDO1 = userMapper.getUserById(1L);
- System.out.println("userDO1 = " + userDO1);
-
- System.out.println("====================");
-
- UserDO userDO2 = userMapper.getUserById(1L);
- System.out.println("userDO2 = " + userDO2);
- }
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。