目录
MapperRegistry和MapperProxyFactory
binding模块主要为了解决一个历史遗留问题,原先查询一个VO对象时需要调用 SqlSession.queryForObject(“selectXXVOById”, primaryKey)方法,执行指定的sql语句,第一个参数selectXXVOById指定了执行的sql语句id,如果我们不小心写错了参数,Mybatis是无法在初始化时发现这个错误的,只会在实际调用queryForObject(“selectXXVOById”, primaryKey)方法时才会抛出异常,就像泛型出来之前,很多类型转换不会在编译期发现错误一样。而binding模块就像 Java的泛型机制 一样,将程序的错误提前暴露出来,为开发人员省去不少排查问题的精力。
Binding模块如何将Mapper接口与映射配置信息相关联,binding模块的解决方案是,定义一个Mapper接口,在接口中定义sql语句对应的方法名Id及参数,这些方法在Mybatis的初始化过程中,会与该Mapper接口对应的映射配置文件中的sql语句相关联,如果存在无法关联的sql语句,Mybatis就会抛出异常,帮助我们及时发现问题。示例代码如下:
public interface HeroMapper {
// 映射文件中会存在一个 <select>节点,id 为 “selectHeroVOById”
public HeroVO selectHeroVOById(int id);
}
// 首先,获取 HeroMapper 对应的代理对象
HeroMapper heroMapper = session.getMapper(HeroMapper.class);
// 直接调用 HeroMapper接口 中的方法&