mybatis中主要类和接口
- Configuration:将mybatis配置文件中的信息保存到该类中
- SqlSessionFactory:解析Configuration类中的配置信息,获取SqlSession
- SqlSession:负责和数据库交互,完成增删改查
- Executor:mybatis的调度核心,负责SQL的生成
- StatementHandler:封装了JDBC的statement操作
- ParameterHandler:负责完成JavaType到jdbcType的转换
- ResultSetHandler:负责完成结果集到Java Bean的转换
- MappedStatement:代表一个select|update|insert|delete元素
- SqlSource:根据传入的ParamterObject生成SQL
- BoundSql:包含SQL和参数信息
在网上找了个流程图帮助理解
1、在和spring和事务集成后,第五步的获取sqlSession会复杂点,上一节已经说过
2、第六步中,userMapper是个单例了,一级缓存会失效,和事务集成后,又会生效
3、第七步之前回去transactionalCacheMannager时,这里集成了redis的缓存,只要实现Cache接口,二级缓存这里看过源码可以发现,cache是一层一层嵌套的,比如LruCache,SerializedCache
4、第八步中routingStatementHandler也就是上面的StatementHandler,但只是相当于一个工厂类,生产PreparedStatementHandler、SimpleStatementHandler、CallableStatementHandler
5、PreparedStatementHandler里包括ParameterHandler处理参数java转换为jdbc,ResultHandler处理jdbc转换成java
6、第九步获取到了PreparedStatementHandler,在这里获取jdbc的connection
7、TypeHandle的运用,转换java类型和jdbc类型