mybatis_13一级缓存
2019-03-06 07:16:33来源:博客园 阅读 ()
1. Mybatis的缓存理解
Mybatis的缓存,包括一级缓存和二级缓存,一级缓存是默认使用的。二级缓存需要手动开启。
一级缓存指的就是sqlsession,在sqlsession中有一个数据区域,是map结构,这个区域就是一级缓存区域。一级缓存中的key是由sql语句、条件、statement等信息组成一个唯一值。一级缓存中的value,就是查询出的结果对象。
二级缓存指的就是同一个namespace下的mapper,二级缓存中,也有一个map结构,这个区域就是一级缓存区域。一级缓存中的key是由sql语句、条件、statement等信息组成一个唯一值。一级缓存中的value,就是查询出的结果对象。
一个唯一值。一级缓存中的value,就是查询出的结果对象。
2 一级缓存
原理:
第一次查询之后, 由sql语句、条件、statement等信息组成一个唯一值作为key存到sqlsession中的map,查询结果作为value:
如果没有进行其他增删改操作的话,再次查询(同第一次查询条件一样)会自动从sqlsession中读取
如果进行了其他增删改操作,再次查询会重新执行SQL语句查询
3.两次相同查询之间不进行其他数据库操作
@Test public void test() throws IOException { InputStream is = Resources.getResourceAsStream("SqlMapConfig.xml"); SqlSessionFactory ssf=new SqlSessionFactoryBuilder().build(is); SqlSession sqlSession=ssf.openSession(); UserMapper mapper=sqlSession.getMapper(UserMapper.class); User user=mapper.findUserById(1); System.out.println("user"+user); //没有进行其他数据库操作,直接再次查询 User user2=mapper.findUserById(1); System.out.println("user"+user2); sqlSession.commit(); sqlSession.close(); } }
测试结果:
4.两次相同查询之间插入一条记录
@Test public void test() throws IOException { InputStream is = Resources.getResourceAsStream("SqlMapConfig.xml"); SqlSessionFactory ssf=new SqlSessionFactoryBuilder().build(is); SqlSession sqlSession=ssf.openSession(); UserMapper mapper=sqlSession.getMapper(UserMapper.class); User user=mapper.findUserById(1); System.out.println("user"+user); //插入一条数据 User user3=new User(); user3.setUsername("刘海柱"); user.setSex("2"); user.setAddress("单挑王"); mapper.save(user3); User user2=mapper.findUserById(10); System.out.println("user"+user2); sqlSession.commit(); sqlSession.close(); }
测试结果:
原文链接:https://www.cnblogs.com/aihuadung/p/10482239.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:Spring IOC源码实现流程
下一篇:Maven入门教程(一)
- redis缓存 2020-06-12
- MyBatis中的$和#,用不好,准备走人! 2020-06-11
- SpringBoot 2.3 整合最新版 ShardingJdbc + Druid + MyBatis 2020-06-11
- 天哪!手动编写mybatis雏形竟然这么简单 2020-06-06
- MyBatis整合双数据源 2020-06-04
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash