mybatis Binding

本文介绍了Mybatis的Binding模块,其目的是提前暴露查询错误,类似Java泛型机制。通过MapperRegistry和MapperProxyFactory,Mybatis将Mapper接口与映射配置相关联。MapperProxy作为InvocationHandler实现方法调用的统一处理。MapperMethod封装了Mapper接口和SQL信息,它的execute()方法依据SqlCommand和MethodSignature执行数据库操作。当执行SQL时,通过SqlSession进行CRUD操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

MapperRegistry和MapperProxyFactory

MapperProxy

MapperMethod

SqlCommand

MethodSignature

execute()方法


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.getMappe
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

骆驼整理说

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值