关键的方法在于new SqlSessionFactoryBuilder().build(reader);
可以看到parser.parse() 返回的结果是Configuration ,而mybatis所有的配置文件初始化在这个类里面,这个是很关键的类。
这里可以看到读取configuration节点,我们知道configuration节点里面有数据源的配置以及xml文件的所在包或者路径。
这里是初始化mappers文件
拿到resource路径进行解析,
从到这里是不是很熟悉,解析xml文件
读取出来insert 、select 、 update 、delete节点。
看到这个应该知道了,
Map<String, NodeHandler> map = new HashMap<String, NodeHandler>(); map.put("trim", new TrimHandler()); map.put("where", new WhereHandler()); map.put("set", new SetHandler()); map.put("foreach", new ForEachHandler()); map.put("if", new IfHandler()); map.put("choose", new ChooseHandler()); map.put("when", new IfHandler()); map.put("otherwise", new OtherwiseHandler()); map.put("bind", new BindHandler());
不同的标签实现不同的类来组装 sql.
最后把初始化的配置数据放到MappedStatement中。
最后的重头戏来了。
看把成功赋值的MappedStatement再次放到configuration中。