MyBatis简而言之就是一个数据库框架,一种用于简化JDBC开发的持久层框架,使用一个框架,我们不仅要知其然更要知其所以然
工作流程:
一些重要概念:
- Configuration:Mybatis 所有的配置信息都维持在Configuration 对象之中
- SqlSession:作为Mybatis 工作的主要顶层API,表示和数据库交互的会话,完成数据库增删查改功能
- Executor:Mybatis 执行器,是Mybatis 调度的核心,负责SQL
- StatementHandler:封装了JDBC Statement 操作,负责对JDBC statement 的操作,如设置参数,将 Statement 结果集转换为List 集合
- ParameterHandler:负责对用户传递的参数转换为JDBC Statement 所需要的参数
- ResultSetHandler:负责将JDBC返回的ResultSet结果集对象转换为List 类型的集合
- MappedStatement:MappedStatement 封装了要执行的sql语句
- MapperProxy,MapperProxyFactory:Mapper 代理,使用原生的Proxy 执行mapper 里的方法
首先来看下new SqlSessionFactoryBuilder*().build(resourceAsReader);这一步都做了些什么
关键步骤parser.parse()*
parseConfiguration(XNode root)就是解析配置文件中各个标签
然后来看mapperElement解析mappers标签还做了什么
在mappers标签中三种配置方式
- package标签 接口所在包,通过name属性指定mapper接口所在的包名
- mapper标签,通过resource属性引入classpath路径的相对资源
- mapper标签,通过class属性指定mapper接口名称
- mapper标签,通过url引入网络资源或者本地磁盘资源(较少使用)
mybatis就会根据不同配置进行解析,比如配置的是<mapper resource="com/i/mapper/FlowerMapper.xml"/>
进入到标记mapperParser.parse*();方法中
到此new SqlSessionFactoryBuilder().build(resourceAsReader)*的工作也差不多完成了
总结一下:解析mybatis-config.xml配置文件生成configurantion对象,并解析mappers标签将对应的mapper接口封装成MapperProxyFactory添加到MapperRegistry的knowsMappers集合中。最后根据SqlSessionFactory构造函数生成SqlSessionFactory
再来看看SqlSession sqlSession = sqlSessionFactory.openSession*()*;方法都做了什么
- SimpleExecutor:封装了jdbc的statement,使用完后直接关闭。
- ReuseExecutor:封装了jdbc的statement,使用完后不直接关闭,放在一个缓存的map里面等待下次使用。
- BatchExecutor:封装了jdbc的statement,有缓存功能,同时支持批量操作。
总结一下:从sqlSessionFactory中获取configuration然后创建对应的Executor对象,通过构造函数生成DefaultSqlSession
关键步骤RecordTypeMapper mapper = sqlSession.getMapper*(RecordTypeMapper.class)*; 来看下是怎么从sqlSession中获取mapper对象的
总结一下:sqlSession.getMapper*(RecordTypeMapper.class)*;其实是从MapperRegistry的knowsmapper中获取mapper接口的MapperProxyFactory对象然后生成并返回一个mapper的代理对象
最后再研究下Property prop = mapper.selectPropertyAutomapping*(1)*;mapper对象执行增删改查的流程
因为此时的mapper对象是一个代理对象,进入的是mapperProxy的invoke方法
总结一下:mapper代理对象执行,根据查询类型执行,首先看二级缓存中有没有,没有的话看一级缓存,也没有就通过PreparedStatement执行sql语句,最后处理ResultSet返回结果
单独来看下handleResultSets处理结果集
总结一下:就是遍历每一行进行处理,从resultset中取出每个字段的值然后通过反射创建对象