第一步下载源码:
https://gitee.com/kingqiu/MybaitsStudy.git
这个是测试用的例子
加载mybaitsConfig.xml配置文件
把xml文件加载成流来读取,这里没什么好说的
构建SqlSessionFactory
使用了建造者模式构建SqlSessionFactory,后面还有很多地方用到了这模式我们进入build方法。主要是生成Configuration,然后在parser.parse()加载配置,重点进入parser.parse()
parser.evalNode(“/configuration”)中/configuration是mybaitsConfig.xml中的标签,里面大概是用org.w3c.dom.Document加载org.w3c.dom.Node然后封装成org.apache.ibatis.parsing.XNode传入parseConfiguration(XNode root)。
这里的字符串是mybaitsConfig.xml中标签重点看中数据库配置和mapper文件加载,先看
加载数据库配置放进Configuration,TransactionFactory加载事务管理器,DataSourceFactory数据源工厂,回到刚才的parseConfiguration(XNode root)方法
进入mapperElement(root.evalNode(“mappers”)),这里是加载配置文件中这里mapper的配置,进入mapperParser.parse();
这里是加载mapper对应的xml文件核心方法,XMLMapperBuilder。
进入configurationElement(parser.evalNode(“/mapper”));
加载mapper.xml中下的全部标签就是我们熟知的标签之类的,这里重点看buildStatementFromContext(context.evalNodes(“select|insert|update|delete”));
跳到这里buildStatementFromContext然后跳到parseStatementNode(),
这里最后加载成MappedStatement放进的configuration的mappedStatements中,MappedStatement是mybaits是非常重要的概念大概就是每一个sql对应一个MappedStatement,sql全部的配置都在里面,后面执行sql时候会用到