Mybatis Provider注解中的method属性详解

环境

MyBatis 3.5.1

结论

  1. 当声明了method属性时,会调用method属性值对应的方法
@DeleteProvider(type = TestProvider.class, method = "abc")
int delete(int id);

class TestProvider {
	public String abc(int id) {
		//...
	}
}
  1. 如果未声明method属性,且type属性声明的类未实现ProviderMethodResolver接口,则会调用Provider中名为provideSql的方法
@DeleteProvider(type = TestProvider.class)
int delete(int id);

class TestProvider {
	public String provideSql(int id) {
		//...
	}
}
  1. 如果未声明method属性,且type属性声明的类实现了ProviderMethodResolver接口,则会调用被Provider注解的方法的同名方法
@DeleteProvider(type = TestProvider.class)
int delete(int id);

class TestProvider implements ProviderMethodResolver {
	public String delete(int id) {
		//...
	}
}

详解

在使用Provider注解时,发现method属性不是必须的,查阅MyBatis API后发现

Since 3.5.1, you can omit method attribute, the MyBatis will resolve a target method via the ProviderMethodResolver interface. If not resolve by it, the MyBatis use the reserved fallback method that named provideSql

从3.5.1版本开始,可以省略method属性,MyBatis将通过ProviderMethodResolver接口解析目标方法,如果解析失败,MyBatis使用名为provideSql的预留备用方法

查看ProviderMethodResolver接口的源码,内含一个resolveMethod方法

default Method resolveMethod(ProviderContext context) {
	//选取实现类中与被注解方法相同名称的方法
    List<Method> sameNameMethods = Arrays.stream(getClass().getMethods())
        .filter(m -> m.getName().equals(context.getMapperMethod().getName()))
        .collect(Collectors.toList());
    if (sameNameMethods.isEmpty()) {
	  //如果不存在相同名称的方法,抛出异常,猜测被上层捕获后去寻找名为provideSql的方法
      throw new BuilderException("Cannot resolve the provider method because '"
          + context.getMapperMethod().getName() + "' not found in SqlProvider '" + getClass().getName() + "'.");
    }
	//在相同名称的方法中继续寻找返回值是CharSequence或其的子类的方法
    List<Method> targetMethods = sameNameMethods.stream()
        .filter(m -> CharSequence.class.isAssignableFrom(m.getReturnType()))
        .collect(Collectors.toList());
    if (targetMethods.size() == 1) {
	  //筛选后方法唯一,找到了
      return targetMethods.get(0);
    }
    if (targetMethods.isEmpty()) {
	  //没有符合条件的方法
      throw new BuilderException("Cannot resolve the provider method because '"
          + context.getMapperMethod().getName() + "' does not return the CharSequence or its subclass in SqlProvider '"
          + getClass().getName() + "'.");
    } else {
	  //有多个符合条件的方法
      throw new BuilderException("Cannot resolve the provider method because '"
          + context.getMapperMethod().getName() + "' is found multiple in SqlProvider '" + getClass().getName() + "'.");
    }
  }

由此可知,未指定method时,Provider实现ProviderMethodResolver接口后会优先寻找方法名相同的方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。
Mybatis的collection标签,常用的属性有: 1. collection:需要遍历的对象,可以是List、Array或Map。 2. item:集合元素迭代时的别名,必选项。 3. index:在List或Array,index为元素的序号索引;在Map,index为遍历元素的key值,可选项。 4. open:遍历集合时的开始符号,通常与close配合使用,可选项。 5. separator:元素之间的分隔符,用于将遍历的元素以指定字符隔开,可选项。 6. close:遍历集合时的结束符号,通常与open配合使用,可选项。 对于collection属性的取值,有以下三种情况: 1. 如果传入的参数类型为List,则collection的默认属性值为"list",也可以使用@Param注解自定义keyName。 2. 如果传入的参数类型为Array,则collection的默认属性值为"array",也可以使用@Param注解自定义keyName。 3. 如果传入的参数类型为Map,则collection的属性值可以是以下三种情况: a. 遍历map的keys; b. 遍历map的values; c. 遍历map的entrySet(),即同时遍历key和value。 以上是Mybatiscollection标签常用的属性属性值的介绍。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [MybatisCollection集合标签的使用详解](https://download.csdn.net/download/weixin_38647822/12724383)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [mybatis collection](https://blog.csdn.net/weixin_44617188/article/details/126680162)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值