Mybatis的具体执行流程如下:
1. 首先mybatis中xml解析是通过SqlSessionFactoryBuilder.build()方法。
2. 初始化mybatis(解析xml文件构建成Configuration对象)并初始化SqlSessionFactory对象
在解析xml时会同时根据其中节点做相应的初始化操作
关键节点: settings、typeAliases、mappers
3. 通过SqlSesssionFactory.openSession()方法打开一个SqlSession对象
SqlSessionFactory对象的作用是里面存了全局的配置信息以及初始化环境和DataSource,DataSource对象可以用来开辟连接,SqlSessionFactory对象是用来保存全局信息并且打开数据库连接
在打开SqlSession对象的时候就会开辟一个连接对象并传给SqlSession对象,和数据库打交道的操作入口在于SqlSession对象
4. 通过SqlSession.getMapper()根据传入的Mapper对象类型动态代理并返回一个动态代理后的Mapper对象
由SqlSession.select()/update(),MapperProxy对象的invoke()方法执行后再执行execure方法,再根据情况选择执行select/update
5. Executor执行Query/queryFromDatabase,在前面经过参数名封装和缓存查询之后(缓存为空),会调用queryFromDatabase方法去数据库当中查
SimpleExecurot执行doQuery()方法,初始化prepareStatement并且给#{}参数赋值
StatementHandler执行query()方法,执行sql语句
ResuletHandler.handleResultSets()方法封装结果集