MyBatis的mapper.xml文件中入参和返回值的实现

 更新时间:2023年01月09日 14:32:22   作者:造化圣者  
这篇文章主要介绍了MyBatis的mapper.xml文件中入参和返回值的实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

mapper.xml文件中入参和返回值的写法

关于MyBatis的mapper.xml文件中入参和返回值的书写的问题,相信很多小伙伴都有这方面的问题,由于mybatis中mapper中的方法参数和返回值类型是变化的,而有时入参或者返回值时可以省略的,而有时有时不可省略的。

这就导致大家不知道parameterType,resultType什么时候可以省略,什么时候不能省略,我就在这里讨论一下这个问题。

resultType

1.对于resultType的情况是比较简单的,一般来说增删改中mapper.xml文件中对应的resultType是不需要写的,因为增删改方法的返回值都是影响行数的int,mybatis自行处理,是不需要写的。

例如:

此处的delete标签中入参为Int,而返回值是影响行数的int,此时的resultType是不需要写的,图中也可以看出:使用idea编写时,也没有提示resultType的属性。所以第一种情况就是当增删改标签中的返回值是不需要写的。

2.当resultType指定查询返回的结果集是集合的类型时,则必须是泛型的类型。

例如:

此处的select标签的返回值是List集合,所以resultType为集合的泛型:users。

所以第二种情况就是:当resultType指定查询返回的结果集是集合的类型时,则必须是泛型的类型。

3.其他情况返回值是什么,resultType对应的填即可。

parameterType

1.当参数≥2个的时候,一般使用@Param(“参数名”)进行注解,标签中是可以通过#{参数名}获取到参数的,所以,此时的parameterType也是不用写的。

例如:

此时的入参是两个String类型的参数,所以此时的parameterType是不需要写的。

2. 当入参参数是集合的时候如List,map等,parameterType的书写是可以省略的。

例如:

此处的insert标签中的返回值是影响行数的int,resultType不需要写,而入参是list,也是直接省略不写。

所以第二种情况:当入参参数是集合的时候如List,map等,parameterType的书写是可以省略的。

3.其他情况下,parameterType均正常填写。

mapper.xml配置文件的参数说明

id:标签只能修改主键字段

  • Result:除了主键以外的字段;
  • Column:数据库中的字段名称;
  • jdbcType:列数据库中字段的类型(可以省略不写);

resultMap的作用

(1)当数据库中字段名与实体类对象的属性名不一致时,可以进行转换;

(2)当前查询的结果没有对应一个表时,可以自定义一个结果集;

Sql语句片段,将公共部分抽取出来,通过include标签进行引用;

Suffixoverrides,去除多余的逗号;

注意:如果数据库中字段名称由多个单词构成,通过mybatis逆向工程生成的对象属性名称会按照驼峰命名法规则生成属性名称,其中:数据库中字段名称由多个单词构成的时候必须使用—下划线分隔。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 如何利用Java在图片上添加文字水印效果

    如何利用Java在图片上添加文字水印效果

    最近发现经常被别的网站盗用,而且不注明出处,因此不得不加上水印,这篇文章主要给大家介绍了关于如何利用Java在图片上添加文字水印效果的相关资料,需要的朋友可以参考下
    2022-01-01
  • SpringBoot中动态更新@Value配置方式

    SpringBoot中动态更新@Value配置方式

    这篇文章主要介绍了SpringBoot中动态更新@Value配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • Java通过JavaMail发送邮件功能

    Java通过JavaMail发送邮件功能

    这篇文章主要为大家详细介绍了Java通过JavaMail发送邮件功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • Java基础之练习打印三角形

    Java基础之练习打印三角形

    这篇文章主要介绍了Java基础之练习打印三角形,文中有非常详细的代码示例,对正在学习java基础的小伙伴们有非常好的帮助,需要的朋友可以参考下
    2021-04-04
  • mybatis批量插入,批量更新以及null值问题的解决

    mybatis批量插入,批量更新以及null值问题的解决

    这篇文章主要介绍了mybatis批量插入,批量更新以及null值问题的解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • 深入分析Java并发编程之CAS

    深入分析Java并发编程之CAS

    这篇文章主要介绍了Java并发编程之CAS的相关资料,帮助大家更好的理解和学习Java并发编程,感兴趣的朋友可以了解下
    2020-08-08
  • Java编写的实体返回VO工具

    Java编写的实体返回VO工具

    VO(value object)通常用于业务层之间的数据传递,VO的属性是根据当前业务的不同而不同的,也就是说,它的每一个属性都一一对应当前业务逻辑所需要的数据的名称。本文将介绍如何将实体转换为vo对象
    2021-05-05
  • 浅谈Spring中Bean的作用域、生命周期

    浅谈Spring中Bean的作用域、生命周期

    这篇文章主要介绍了浅谈Spring中Bean的作用域、生命周期,具有一定借鉴价值,需要的朋友可以参考下
    2018-01-01
  • Java如何获取枚举类型的值

    Java如何获取枚举类型的值

    这篇文章主要介绍了Java如何获取枚举类型的值问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • 详解定时任务框架Quartz的使用

    详解定时任务框架Quartz的使用

    Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目,完全由Java开发,可以用来执行定时任务,本文就来带大家聊聊它的具体使用
    2023-02-02

最新评论