Mybatis如何传入多个参数的实现代码

 更新时间:2019年12月17日 11:45:24   作者:培珺  
这篇文章主要介绍了Mybatis如何传入多个参数的实现代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

第一种方式:使用@Param注解方式

此种方式用法是我们在接口中写方法的参数时,在每个参数的前面加上一个@Param注解即可。

该注解有一个value属性,我们可以给加上注解的参数取个名字,在SQL语句中我们可以通过这个名字获取参数值。

由于传入了多个参数,所以映射文件的入参ParameterType不用写。

假如我们在接口的方法如下:

//根据传入的用户名和主键id去修改用户名
int updateUserByManyParam(@Param("name")String username,@Param("id")Integer id);

我们先在映射文件里面瞎写看看控制台会报什么错误:

//错误实例:
<update id="updateUserByManyParam">
 update user set username = #{name1} where id = #{oid}
</update>

好了,看看控制台报了什么错:

//错误信息
Cause: org.apache.ibatis.binding.BindingException: Parameter 'name1' not found.
Available parameters are [name, id, param1, param2]

从错误信息我们可以看到,它说找不到name1参数,存在的参数有name, id, param1, param2,那么我们按照控制台说的来就可以了。

①按照指定的参数名

<update id="updateUserByManyParam">
 update user set username = #{name} where id = #{id}
</update>

②按照参数的顺序

<update id="updateUserByManyParam">
  update user set username = #{param1} where id = #{param2}
</update>

第二种方式:按照参数的编写顺序

此种方式我们在传入参数的时候什么都不用做就行了,只要在SQL语句中按照规则获取参数值即可。

假如我们在接口的方法如下:

//根据传入的用户名和主键id去修改用户名
int updateUserByManyParam(@Param("name")String username,@Param("id")Integer id);

我们和上面一样,先在映射文件里面瞎写看看控制台会报什么错误:

//错误实例:
<update id="updateUserByManyParam">
 update user set username = #{ddd} where id = #{fff}
</update>

好了,看看控制台报了什么错:

//错误信息:
Cause: org.apache.ibatis.binding.BindingException: Parameter 'ddd' not found. 
Available parameters are [arg1, arg0, param1, param2]
 

从错误信息我们可以看到,它说找不到ddd参数,存在的参数有arg1, arg0, param1, param2,那么我们按照控制台说的来就可以了。

①按照参数的顺序

<update id="updateUserByManyParam">
  update user set username = #{arg0} where id = #{arg1}
</update>
 

②按照参数的顺序

<update id="updateUserByManyParam">
  update user set username = #{param1} where id = #{param2}
</update>

总结

  • 使用@Param注解方式,在SQL语句中我们可以按照自定义的名称获取参数值,也可以用param1、param2、…顺序来获取参数值。
  • 直接传入参数,在SQL语句中按照参数传递的顺序,利用arg1、arg2、…顺序获得对应的参数值。
  • 直接传入参数,在SQL语句中按照参数传递的顺序,利用param1、param2、…顺序来获取参数值。

注意:param后面的数字是从1开始的,而arg后面的数字是从0开始的。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • springboot与vue实现简单的CURD过程详析

    springboot与vue实现简单的CURD过程详析

    这篇文章主要介绍了springboot与vue实现简单的CURD过程详析,围绕springboot与vue的相关资料展开实现CURD过程的过程介绍,需要的小伙伴可以参考一下
    2022-01-01
  • 解决SpringMvc后台接收json数据中文乱码问题的几种方法

    解决SpringMvc后台接收json数据中文乱码问题的几种方法

    本篇文章主要介绍了解决SpringMvc后台接收json数据中文乱码问题的几种方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • Java中BigDecimal类的简单用法

    Java中BigDecimal类的简单用法

    这篇文章主要介绍了Java中BigDecimal类的简单用法,是Java应用程序开发中非常实用的技巧,本文以实例形式对此进行了简单的分析,需要的朋友可以参考下
    2014-09-09
  • Java 深入学习static关键字和静态属性及方法

    Java 深入学习static关键字和静态属性及方法

    这篇文章主要介绍了Java 深入学习static关键字和静态属性及方法,文章通过围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-09-09
  • java区分绝对路径和相对路径的方法

    java区分绝对路径和相对路径的方法

    这篇文章主要介绍了java区分绝对路径和相对路径的方法,实例分析了java针对路径操作的相关技巧,需要的朋友可以参考下
    2015-04-04
  • SpringBoot实现热部署Community的示例代码

    SpringBoot实现热部署Community的示例代码

    本文主要介绍了SpringBoot实现热部署Community的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • 详析Spring中依赖注入的三种方式

    详析Spring中依赖注入的三种方式

    在开发的过程中突然对Spring的依赖注入几种方式出现混交,打算做个简单的小结,方便大家和自己以后参考借鉴,如有总结不对的地方,请大家不吝指教!下面来一起看看吧。
    2016-09-09
  • Java IO流之原理分类与节点流文件操作详解

    Java IO流之原理分类与节点流文件操作详解

    流(Stream)是指一连串的数据(字符或字节),是以先进先出的方式发送信息的通道,数据源发送的数据经过这个通道到达目的地,按流向区分为输入流和输出流
    2021-10-10
  • java中如何获取线程名称

    java中如何获取线程名称

    这篇文章主要介绍了java中如何获取线程名称问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06
  • spring-boot-starter-web更换默认Tomcat容器的方法

    spring-boot-starter-web更换默认Tomcat容器的方法

    Spring Boot支持容器的自动配置,默认是Tomcat,当然我们也是可以进行修改的。下面小编给大家带来了spring-boot-starter-web更换默认Tomcat容器的方法,感兴趣的朋友跟随小编一起看看吧
    2019-04-04

最新评论