01、MyBatis主要的工作流程
02、MyBatis架构分层与模块划分
【1】、包结构
【2】、架构图
1、接口层
接收到调用请求的时候,会调用核心处理层的相应模块来完成具体的数据库操作。
2、核心处理层
把接口中传入的参数解析并且映射成JDBC类型;解析xml文件中的SQL语句,包括插入参数,和动态SQL的生成;执行SQL语句;处理结果集,并映射成Java对象。
3、基础支持层
抽取出来的通用的功能,比如:数据源、缓存、日志、xml解析、反射、IO、事务等等这些功能。
03、MyBatis缓存
【1】、一级缓存(本地缓存)
一级缓存是在会话(SqlSession)层面进行缓存的。MyBatis的一级缓存是默认开启。
同一个会话里面,多次执行相同的SQL语句,会直接从内存取到缓存的结果,不会再发送SQL到数据库。但是不同的会话里面,即使执行的SQL一模一样(通过一个Mapper的同一个方法的相同参数调用),也不能使用到一级缓存。
缺点:
因为缓存不能跨会话共享,不同的会话之间对于相同的数据可能有不一样的缓存。在有多个会话或者分布式环境下,会存在脏数据的问题。
如果关闭一级缓存?
private TaskInfoMapper mapper = null;
private SqlSession session = null;
public TaskInfoDao() {
this.session = new MybatisUtil().getSqlSession(true);
this.mapper = session.getMapper(TaskInfoMapper.class);
}
public List<TaskQuery> findTaskInfo(TaskQuery taskQuery) {
session.clearCache();
return mapper.findTaskInfo(taskQuery);
}
【2】、二级缓存
二级缓存是用来解决一级缓存不能跨会话共享的问题的,范围是namespace级别。可以被多个SqlSession共享,生命周期和应用同步。
开启二级缓存
修改配置文件mybatis-config.xml加入<setting name="cacheEnabled"value="true"/>,全局配置参数,需要时再设置
在mapper.xml中开启二缓存,mapper.xml下的sql执行完成会存储到它的缓存区
注意:开启缓存的弊端是数据没有实时性,当数据库中的数据一旦修改,查询的数据还是缓存中的数据没有实时性,对于某些需要实时性显示数据的接口我们可以设置useCache="false",设置该属性后,该接口每次查询出来都是去执行sql查询出实时性数据。
<select id="findOrderListResultMap" resultMap="ordersUserMap" useCache="false">