MyBatis 原理

MyBatis 是 Apache 下的一个开源项目,原名为iBatis,后来因为项目托管平台迁移,更名为 MyBatis,它采用配置文件动态管理SQL语句,包含输入输出类型映射,数据库连接池配置的持久层框架。

1、MyBatis 整体架构

MyBatis 包含数据源配置文件, SQL 映射配置文件,会话工厂,会话,执行器及底层封装对象。

SQL 映射文件,包含select,update,insert标签,parameterType指定输入参数类型,resultType用于指定返回类型。

resultMap用于定义复杂的包含其他Bean的 Java Bean 对象,结合 association,collection 实现多表关联。

 

2、MyBatis 运行流程

通过Resource资源加载类读取 MyBatis 的全局配置文件 mybatis-config.xml,生成 SqlSessionFactory 会话工厂,会话工厂生成 SqlSession 会话对象,会话对象内部通过 Executor 接口对数据库进行增删改查操作。Executor 接口内部依赖 MappedStatement 底层封装对象,即对SQL语句ID,输入参数,输出结果类型的映射信息进行封装。

 

3、MyBatis 基本执行器

BaseExecutor 基本执行器有三种,SimpleExecutor,ReuseExecutor,和BatchExecutor,默认为SimpleExecutor。

SimpleExecutor,简单执行器,没执行一次select/update语句,开启一个Statement对象,用完立刻关闭。

ReuseExecutor,可重复使用执行器,会缓存同一个sql的Statement对象,存在就使用,不存在就创建,用完后不关闭,供下次使用。

BatchExecutor,批处理执行器,用于执行update,将所有sql添加到批处理中,等待统一执行。

执行器为SimpleExecutor和ReuseExecutor时,insert,update,delete方法的返回值可以用于判断sql执行是否成功,0表示执行失败,非0表示sql执行影响条目数。

BatchExecutor时,这三种方法返回结果值为-2147482646,不能用于判断sql语句是否执行成功。

 

4、MyBatis 插件

MyBatis中,针对某种方法进行拦截调用的机制,成为插件plugin,允许拦截方法的接口有Executor,ParameterHandler,ResultSetHandler,和StatementHandler。

实现一个 plugin,需要继承Interceptor接口,并且制定需要拦截的方法的签名,例如 mybatis-plus 提供的PaginationInterceptor分页插件,

@Intercepts({@Signature(type = StatementHandler.class, method = "prepare", args = {Connection.class, Integer.class})})
public class PaginationInterceptor extends AbstractSqlParserHandler implements Interceptor {
}

之后注册此插件即可。

 

5、MyBatis 高级映射及延迟加载

主要用于多表关联查询的情况,先查单表,需要时再进行关联表查询,延迟加载可以提高查询效率。

association,collection具有延迟加载的功能,在使用时,需要先开启延迟加载功能,Spring Boot 中设置如下属性:

mybatis:
  configuration:
    lazy-loading-enabled: true #延迟加载
    aggressive-lazy-loading: false #按需加载

6、MyBatis 缓存

MyBatis 提供一级缓存和二级缓存机制,MyBatsi 默认支持一级缓存。

1)一级缓存

一级缓存为SqlSession级别的缓存,每个SqlSession类的实例对象内部有一个HashMap数据结构,用于存储缓存数据,当执行了commit操作时,一级缓存区域会清空。

在查询缓存数据之前,如果发生了增删改等操作,SqlSession 实例会清空其一级缓存区域。

2)二级缓存

二级缓存是Mapper级别的缓存,是跨SqlSession的,多个SqlSession类的对象操作同一个Mapper配置文件中的SQL语句时,会共享一个Mapper缓存。SqlSession 类的实例对象会先查询 Mapper 的缓存区域,如果不存在就查数据库,然后将结果放到缓存区域,下次查询相同数据时直接从缓存区域中取;当某个SqlSession类的实例对象执行了增删改等操作时,Mapper实例会清空其二级缓存。

 

7、Mapper 动态代理

需要遵守一定的开发规范,即可实现 Mapper 动态代理,这样只需要编写DAO 层接口和对应的Mapper映射文件,交互方法由 MyBatis 框架来完成,使开发更加简洁。

接口中的方法名,参数和返回类型,和 Mapper 映射文件中定义的id,输入类型,输出类型相同,然后指定映射文件的namespace 为Mapper 接口路径即可。

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值