概念
-
MyBatis是一个半ORM框架,它内部封装了JDBC,开发时只需要关注SQL语句本身。程序员直接编写原生态sql语句,可以严格控制sql执行性能,灵活度高
MyBatis从执行sql语句到返回results的过程
-
通过xml或注解的方式将要执行的statement配置起来
-
通过Java对象和statement中sql的动态参数进行映射生成最终执行的sql语句
-
MyBatis框架执行sql并将结果映射为Java对象返回
Dao/Mapper接口的工作原理
-
JDK动态代理,MyBatis运行时会使用JDK动态代理为Mapper接口生成代理对象proxy,代理对象会拦截接口方法,转而执行MapperStatement所代表的sql,然后返回sql执行结果
延迟加载
-
MyBatis仅支持association关联对象和collection关联对象的延迟加载
-
它的原理是,使用CGLIB创建目标对象的代理对象,当调用目标方法时,进入拦截器方法,比如调用a.getB().getName(),拦截器invoke()方法发现a.getB()是null值,那么就会单独发送事先保存好的查询关联B对象的sql,把B查询上来,然后调用a.setB(b),于是a的对象b属性就有值了,接着完成a.getB().getName()方法的调用。这就是延迟加载的基本原理。
MyBatis的一级、二级缓存
-
一级缓存:基于PerpetualCache,使用HashMap本地存储,存储作用域为Session,一级缓存默认打开,当Session flush或close之后,该Session中的所有Cache将清空
-
二级缓存:基于PerpetualCache,使用HashMap存储,存储作用域为Mapper(namespace),可以自定义存储源,默认不打开二级缓存,如果要打开二级缓存,需要实现序列化接口,并在映射文件中配置<cache/>
-
缓存更新:当某个作用域进行了C/D/U操作后,默认该作用域下select中的缓存将被clear并重新更新,如果开启了二级缓存,则只根据配置判断是否刷新
使用MyBatis的Mapper接口调用时的要求
-
Mapper接口方法名要和mapper.xml中定义的每个sql的id相同
-
Mapper接口输入参数的类型要和mapper.xml中每个sql的parameter Type类型相同
-
Mapper接口输出参数的类型要和mapper.xml中每个sql语句的resultType的类型相同
-
Mapper接口的类路径要和mapper.xml文件中的namespace相同