自定义最简单Mybatis

  1. 要干什么? 什么时候干?
  2. 流程
    在这里插入图片描述
  3. 步骤分解
    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集合就有20
10条信息。

现在Configuration已经具备了操作数据库的能力,那么再加上getDataSource和getConnection,其他的类只要有调用Configuration的getConnection就可以操作数据库。

3.2 执行
要考虑一下什么时候干
在这里插入图片描述
defaultSqlSession一定具备操作数据库的能力,但是它不知道怎么使用。相当于一个前辈把毕生内力传给了你,你使不出来。你家有矿,钥匙在你爹手里。 因为configuration里面map的mapper中可能有N条数据,而SQL是当做value存的,需要key。key在UserMapper.java手里。
在这里插入图片描述
在这里插入图片描述

3.3 解析,封装(用JDBC元数据对结果集进行解析)
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值