- 要干什么? 什么时候干?
- 流程
- 步骤分解
3.1 解析封装
主要是要搞清楚Configuration中Map<String, Mapper> mapper的结构:
在SqlMapConfig.xml的标签里面可以有多个, 一个UserMapper.xml可以有多个 标签。
Map<String, Mapper>:
String=key=namespace+id;Mapper=value={sql, resultType}
//
每次解析一个xxxMapper.xml完成以后
cfg.setMappers(mappers);
//在configuration中set方法的实现是put 是合并
/
* HaspMap的putAll方法 是多个mapper的合并
* map1 : {1=a, 2=b, c=3 }
* map2 : {4=d, 5=e}
* map2.putAll(map1);
* map2 : {1=a, 2=b, c=3, 4=d, 5=e}
* /
public void setMappers(Map<String, Mapper> mappers) {
this.mappers.putAll(mappers);
}
/*******/
比如说
数据库一张表 对应一个javaBean —>javaBeanMapper.java(增删改查各种操作) -->javaBeanMapper.xml(增删改查各种操作的SQL语句)
假设现在有20张表, 每张表有10种操作, 最终map集合就有2010条信息。
现在Configuration已经具备了操作数据库的能力,那么再加上getDataSource和getConnection,其他的类只要有调用Configuration的getConnection就可以操作数据库。
3.2 执行
要考虑一下什么时候干
defaultSqlSession一定具备操作数据库的能力,但是它不知道怎么使用。相当于一个前辈把毕生内力传给了你,你使不出来。你家有矿,钥匙在你爹手里。 因为configuration里面map的mapper中可能有N条数据,而SQL是当做value存的,需要key。key在UserMapper.java手里。
3.3 解析,封装(用JDBC元数据对结果集进行解析)