MyBatis源码分析

1 创建SqlSessionFacotry的过程

SqlSessionFactoryBuilder().build(inputStream);
根据配置文件初始化出Configuration对象
解析文件的每一个信息保存在Configuration中,返回包含Configuration的DefaultSqlSession;


2、获取sqlSession对象

他里面包含了Executor(是用来增删改查的)和Configuration。
    1. sqlSessionFactory.openSession();
   2. 创建:获取一些信息 创建事务Transaction tx
    3. configuration.newExecutor
   根据Exector在全局配置中的类型,
   创建出 BatchExecutor/ReuseExecutor/SimpleExecutor
   4. 判断是否配置了二级缓存:


if (cacheEnabled)
进行封装
executor = new CachingExecutor(executor);
5. 根据某列的值改变封装行为


返回一个DefaultSQlSession对象,包含Executor和Configuration;
这一步会创建Executor对象;
Executor(根据全局配置文件中的defaultExecutorType创建出对应的Executor)


3、获取接口的代理对象(MapperProxy)


DefaultSqlSession.getMapper():拿到Mapper接口对应的MapperProxy;
使用MapperProxyFactory创建一个MapperProxy的代理对象
代理对象里面包含了,DefaultSqlSession(Executor)


4、执行增删改查方法


1)调用DefaultSqlSession的增删改查(Executor);
2)会创建一个StatementHandler对象。
(同时也会创建出ParameterHandler和ResultSetHandler)
3)调用StatementHandler预编译参数以及设置参数值;
使用ParameterHandler来给sql设置参数
4)调用StatementHandler的增删改查方法;
5)ResultSetHandler封装结果
 

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值