## 概念
存在于内存中的临时数据.减少数据库交互,提高执行难效率.
## 一级缓存概念
一级缓存默认是开启的.它指的是MyBatis中SqlSession对象的缓存.当我们执行查询之后,查询的结果会同时存入SqlSession到为我们提供的一块区域中.该区域的结构是一个Map,当我们再次查询同样的数据,MyBatis会先去SqlSession查询是否有,有的话直接拿出来使用.当SqlSession消失时MyBatis的一级缓存也就消失了.
## 实例
~~~
IUserDao mapper = session.getMapper(IUserDao.class);
User user1 = mapper.findById(41);
System.out.println(user1);
User user2 = mapper.findById(41);
System.out.println(user2);
~~~
```
2019-04-04 21:00:26,953 0 [ main] DEBUG ache.ibatis.logging.LogFactory - Logging initialized using 'class org.apache.ibatis.logging.log4j.Log4jImpl' adapter.
2019-04-04 21:00:27,168 215 [ main] DEBUG ansaction.jdbc.JdbcTransaction - Opening JDBC Connection
2019-04-04 21:00:27,420 467 [ main] DEBUG ansaction.jdbc.JdbcTransaction - Setting autocommit to false on JDBC Connection [com.mysql.jdbc.JDBC4Connection@1b26f7b2]
2019-04-04 21:00:27,429 476 [ main] DEBUG com.like.dao.IUserDao.findById - ==> Preparing: select * from user where id = ? //只查询了一次
2019-04-04 21:00:27,473 520 [ main] DEBUG com.like.dao.IUserDao.findById - ==> Parameters: 41(Integer)
2019-04-04 21:00:27,502 549 [ main] DEBUG com.like.dao.IUserDao.findById - <== Total: 1
User{id=41, username='老王', birthday=Tue Feb 27 17:47:08 CST 2018, sex='男', address='北京', accounts=null}
User{id=41, username='老王', birthday=Tue Feb 27 17:47:08 CST 2018, sex='男', address='北京', accounts=null}
2019-04-04 21:00:27,506 553 [ main] DEBUG ansaction.jdbc.JdbcTransaction - Resetting autocommit to true on JDBC Connection [com.mysql.jdbc.JDBC4Connection@1b26f7b2]
2019-04-04 21:00:27,507 554 [ main] DEBUG ansaction.jdbc.JdbcTransaction - Closing JDBC Connection [com.mysql.jdbc.JDBC4Connection@1b26f7b2]
```
## 关闭session
~~~
SqlSession session1 = build.openSession();
IUserDao mapper1 = session1.getMapper(IUserDao.class);
User user1 = mapper1.findById(41);
System.out.println(user1);
session1.close();
SqlSession session2 = build.openSession();
IUserDao mapper2 = session2.getMapper(IUserDao.class);
User user2 = mapper2.findById(41);
System.out.println(user2);
~~~
可以看到查询了两次:
```
2019-04-04 21:02:08,396 0 [ main] DEBUG ache.ibatis.logging.LogFactory - Logging initialized using 'class org.apache.ibatis.logging.log4j.Log4jImpl' adapter.
2019-04-04 21:02:08,633 237 [ main] DEBUG ansaction.jdbc.JdbcTransaction - Opening JDBC Connection
2019-04-04 21:02:08,900 504 [ main] DEBUG ansaction.jdbc.JdbcTransaction - Setting autocommit to false on JDBC Connection [com.mysql.jdbc.JDBC4Connection@eafc191]
2019-04-04 21:02:08,909 513 [ main] DEBUG com.like.dao.IUserDao.findById - ==> Preparing: select * from user where id = ?
2019-04-04 21:02:08,972 576 [ main] DEBUG com.like.dao.IUserDao.findById - ==> Parameters: 41(Integer)
2019-04-04 21:02:08,999 603 [ main] DEBUG com.like.dao.IUserDao.findById - <== Total: 1
User{id=41, username='老王', birthday=Tue Feb 27 17:47:08 CST 2018, sex='男', address='北京', accounts=null}
2019-04-04 21:02:09,003 607 [ main] DEBUG ansaction.jdbc.JdbcTransaction - Resetting autocommit to true on JDBC Connection [com.mysql.jdbc.JDBC4Connection@eafc191]
2019-04-04 21:02:09,004 608 [ main] DEBUG ansaction.jdbc.JdbcTransaction - Closing JDBC Connection [com.mysql.jdbc.JDBC4Connection@eafc191]
2019-04-04 21:02:09,006 610 [ main] DEBUG ansaction.jdbc.JdbcTransaction - Opening JDBC Connection
2019-04-04 21:02:09,019 623 [ main] DEBUG ansaction.jdbc.JdbcTransaction - Setting autocommit to false on JDBC Connection [com.mysql.jdbc.JDBC4Connection@78ac1102]
2019-04-04 21:02:09,020 624 [ main] DEBUG com.like.dao.IUserDao.findById - ==> Preparing: select * from user where id = ?
2019-04-04 21:02:09,021 625 [ main] DEBUG com.like.dao.IUserDao.findById - ==> Parameters: 41(Integer)
2019-04-04 21:02:09,022 626 [ main] DEBUG com.like.dao.IUserDao.findById - <== Total: 1
User{id=41, username='老王', birthday=Tue Feb 27 17:47:08 CST 2018, sex='男', address='北京', accounts=null}
```
## 手动清空缓存
~~~
session.clearCache();
~~~
## 触发清空一级缓存的情况
当调用session的修改,添加,删除,commit(),close()等方法时,就会清空一级缓存.
- Maven
- 概述
- 常用命令
- 生命周期
- scope详解
- maven概念模型图
- IDEA创建maven工程
- 创建maven web项目
- 冲突解决
- pom文件标签详解
- maven工程拆分与聚合的思想
- 父子工程的创建
- 工程和模块的关系以及集成和依赖的概念
- 父子工程添加依赖
- 父子工程的三种启动方式
- Struts2
- 执行流程
- 配置
- action的使用
- 获取Servlet的API
- result标签的视图配置
- struts2属性封装
- struts2模型封装
- OGNL
- 值栈(ValueStack)
- 值栈context区存数据
- 值栈root区
- struts2对el的增强
- #,%,$符号使用
- 值栈扩展
- 拦截器
- 自定义拦截器
- 方法拦截器
- 注解方式
- Hibernate
- 配置
- 简单crud
- 持久化类编写规范
- OID
- 持久化类三种状态
- 一级缓存
- 查询
- session与当前线程绑定
- hibernate一对多配置
- 冗余SQL语句的原因
- hibernate多对多配置
- 级联操作
- 对象导航查询
- JPA
- JPA单表CRUD
- JPA多种查询
- JPA一对多关系映射
- JPA一对多操作
- JPA多对多关系映射
- JPA多对多操作
- QBC查询
- 离线条件查询(DetachedCriteria)
- SpringMVC
- 环境搭建
- 常用注解
- 请求参数绑定
- 绑定基本类型和字符串
- 绑定实体类型
- 解决中文乱码
- 绑定集合类型
- 自定义类型转换器
- 获取Servlet的API
- 响应字符串
- 响应void
- 响应ModelAndView
- 响应forward和redirect
- 响应过滤静态资源
- 响应json
- 文件上传基础
- SpringMVC上传文件
- 跨服务器文件上传
- 拦截器
- SpringMVC异常
- ControllerAdvice
- SpringMVC默认处理方式
- 概述
- @ExceptionHandler
- 消息转换器
- SpringMVC跨域
- Spring
- 概述
- IoC快速入门
- ApplicationContext三个常用实现类
- beanFactory和ApplicationContext区别
- bean创建三种方式
- POJO和Javabean的区别
- bean作用范围
- bean对象生命周期
- spring的依赖注入
- DI的属性注入方式
- 常用注解
- Spring新注解
- Spring整合连接池
- Spring的IOC注解配置
- Spring完全使用注解
- Spring整合junit
- AOP
- AOP配置
- JDBCTemplate
- JDBCTemplate在IOC中使用
- JDBCTemplate的CRUD
- JDBCTemplate在dao中使用
- 声明式事务
- spring事务API
- 事务XML配置
- 事务注解配置
- 全注解事务
- Spring编程式事务
- 整合SSH(XML版本)
- 整合SSH(半XML半注解)
- Spring5新特性
- MyBatis
- 概述
- 用maven创建MyBatis
- 将数据库配置单独文件
- typeAliases标签
- MyBatis的CRUD
- MyBatis实现Dao层开发
- 使用dao和代理类的区别
- MyBatis连接池
- MyBatis事务
- MyBatis动态SQL
- 多表操作
- 多表一对一
- 多表一对多
- 多表多对多
- JNDI
- 延迟加载和立即加载
- 延迟加载
- 一级缓存
- 二级缓存
- MyBatis注解
- MyBatis注解CRUD
- 注解实体类属性和字段对应关系
- MyBatis注解一对一和一对多
- MyBatis注解二级缓存
- SSM整合
- 搭建环境
- SpringBoot
- SpringBoot核心功能
- 快速入门
- SpringBoot配置文件
- yml配置文件语法
- 配置文件与配置类的属性映射方式
- 端口和映射路径
- 日志级别
- 访问静态资源
- SpringBoot注入方式一
- SpringBoot注入方式二
- 拦截器
- HikariCP连接池
- SpringBoot集成MyBatis
- 通用mapper
- SpringBoot事务
- SpringBoot集成Junit
- SpringBoot集成DataJPA
- SpringBoot集成Redis
- 使用SpringBoot提供的测试启动类
- 使用MockMvc
- SpringCloud
- RestTemplate
- Eureka概述
- Eureka快速入门
- Eureka集群
- Eureka客户端
- Eureka失效剔除和自我保护
- 负载均衡Ribbon
- Hystrix
- Hystrix服务降级
- Hystrix服务熔断
- Feign
- Feign的熔断机制
- Feign的请求压缩和日志级别
- Zuul网关
- Zuul快速入门
- Zuul路由规则
- Zuul过滤器
- Zuul自定义过滤器
- Zuul负载均衡和熔断
- Zuul高可用
- Zuul网关缓存
- SpringSecurity
- 快速入门
- SpringSecurity使用数据库认证