getSqlSessionFactory
1.new SqlSessionFactoryBuilder().bulid(全局配置文件的流in)
2.build(in) 进入build(in)
3.parser = new XMLconfigurationBuilder(in) 创建解析器解析 全局配置文件
build(parser.parse()) 进入parse() 方法
4.parse()最后返回的 是 configuration
parseConfiguration(parse.evalNode("/configuration")) 解析全局配置文件configuration节点
5.解析每一个标签,set configuration
6.mapperParser = new XMLMappedBuilder(mapper.xml的 流 )
7.解析 mapper.xml,并且保存在configuration中,并且将mapper.xml中crud标签的每一个标签都解析出来
封装成一个mappedStatement,并将它add configuration
(一个mappedStatnebt代表一个crud标签的 详细信息)
8.返回configuration build(parser.parse()) 结束
9.build(in),结束返回一个 new DefaultSqlSessionFactory(configuration)
返回一个sqlSessionFactory
openSession()
1.return openSessionFromDataSource(configuration.getDefalutExecutorType,...)
getDefaultExecutorType 拿到执行器的类型
默认是Simple,还有 REUSE(可复用的执行器),BATCH(可批量操作的执行器)
2.进入 openSessionFromDataSource
1.configuration.getEnvironment()
configuration.getTransation()
获得 全局配置文件的 环境,事务等信息
2.Executor executor = configuration.newExecutor(tx,execType) 四大对象之一
默认拿到的 是 SimpleExecutor(根据 exeTpye 的值 创建不同的 executor)
下面都是对 executor的 封装
3.if(cacheEnabled) 是否配置了二级缓存
若是,将executor包装成 cachingExecutor
executor = new CachingExecutor(executor)
包装的好处:在查询之前先用cachingExecutor查询缓存,然后再用executor去查询
4.executor = (Executor) interceptorChain.piuginAll(executor)
这是最终的executor,拦截器链连接executor,然后用每一个拦截器包装executor
最终返回executor
5.return DefalutSqlSession(configuration.executor,autoCommit)
最终返回一个defalutSqlSession(包含 configuration,和 executor)
|