广告
返回顶部
首页 > 资讯 > 精选 >mybatis中@Param注解总是报取不到参数问题如何解决
  • 150
分享到

mybatis中@Param注解总是报取不到参数问题如何解决

2023-07-02 16:07:02 150人浏览 安东尼
摘要

这篇文章主要介绍“mybatis中@Param注解总是报取不到参数问题如何解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mybatis中@Param注解总是报取不到参数问题如何解决”文章能帮助大

这篇文章主要介绍“mybatis中@Param注解总是报取不到参数问题如何解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mybatis中@Param注解总是报取不到参数问题如何解决”文章能帮助大家解决问题。

@Param注解总是报取不到参数

SpringBoot+mybatis项目中,在mapper 层传多个参数,请求时总是报参数取不到,快疯了,我发誓xml层没问题,mapper层参数名也没问题

错误如下

mybatis中@Param注解总是报取不到参数问题如何解决

百度了好久,一直让我检查.xml文件是否存在问题,各种方法都尝试遍了,没用。。。

最后检查来检查去发现自己@param注解包导错了,param注解应该用的是ibatis包的,而我导错了,如下:


mybatis中@Param注解总是报取不到参数问题如何解决
 

我用的idea工具开发,直接alt+回车键快捷导入包,没太注意引错了,编译也没报错,坑。。。。

应该导入:import org.apache.ibatis.annotations.Param,ibatis是mybatis的前身,mybatis是由ibatis发展而来。

注意:

其实就是个很小的问题,还有个需要注意的就是在mapper 层,如果只有一个参数不需要@param注解,如果有多个参数,必须要@param()注解,指明每个参数的参数名,否则也会报找不到参数问题,因为 mybatis注解配置使用ognl表达式,这样才能正常的通过注解传值和取值多个参数的问题。

@Param注解详细使用方法

1.@Param这个注解是用来解决接口方法有多个参数时

xxMapper.xml文件绑定参数混淆问题。

需要在DAO方法形参前面添加@Param(“xxx”),来区分不同的需要绑定到xxMapper.xml的参数。

注意双引号里的值要与xxMapper.xml中#{}中的值相等,如:

DAO方法:

public void list (@Param(“abc1”) String abc1, @Param(“abc2”) String abc2);

xxMapper.xml中:

values(#{abc1},#{abc2}

2.可以修饰JavaBean对象、Map集合

如:

public void list (@Param(“param”) User user);

xxMapper.xml中:

where username = #{param.userName}List getUser(@Param(“param”) Map map);

xxMapper.xml中values:

(#{param.id},#{param.name},#{param.age},#{param.sex})

3.@Param参数其实可加可不加

不加的话按照顺序依次取出,如参数User user中userName和passWord的值添加到#{userName}#{password}。

但是当DAO方法里多个参数没有封装在一个Javabean中时,则必须加。或者DAO方法参数里有一个以上的JavaBean、集合等情况下也必须加,如:

@Param(“user”) User user, @Param(“example”) Map map

4.使用@Param注解好处

方法参数名可以不与xxMapper.xml一致,但是注意@Param("")里面的值要与要与xxMapper.xml中#{}里的值一致就可以了,如:

@Param(“user123”) User user#{user123.userName}

关于“mybatis中@Param注解总是报取不到参数问题如何解决”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网精选频道,小编每天都会为大家更新不同的知识点。

--结束END--

本文标题: mybatis中@Param注解总是报取不到参数问题如何解决

本文链接: https://www.lsjlt.com/news/343200.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mybatis中@Param注解总是报取不到参数问题如何解决
    这篇文章主要介绍“mybatis中@Param注解总是报取不到参数问题如何解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mybatis中@Param注解总是报取不到参数问题如何解决”文章能帮助大...
    99+
    2023-07-02
  • mybatis中@Param注解总是报取不到参数问题及解决
    目录@Param注解总是报取不到参数错误如下@Param注解详细使用方法1.@Param这个注解是用来解决接口方法有多个参数时2.可以修饰JavaBean对象、Map集合等3.@Pa...
    99+
    2022-11-13
  • Mybatis Mapper中多参数方法不使用@param注解报错的解决
    目录问题描述寻求解决方案寻找原因拓展延伸在使用低版本的Mybatis的时候,Mapper中的方法如果有多个参数时需要使用@param注解,才能在对应xml的sql语句中使用参数名称获...
    99+
    2022-11-12
  • 如何解决MyBatis中Enum字段参数解析问题
    小编给大家分享一下如何解决MyBatis中Enum字段参数解析问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!基础Class和TypeHandlerMyBati...
    99+
    2023-06-20
  • 如何解决javaBean json传参首字母大写获取不到的问题
    本篇内容介绍了“如何解决javaBean json传参首字母大写获取不到的问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!javaBean...
    99+
    2023-06-20
  • 如何解决ajax回调函数中使用$(this)取不到对象的问题
    本篇内容主要讲解“如何解决ajax回调函数中使用$(this)取不到对象的问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何解决ajax回调函数中使用$(t...
    99+
    2022-10-19
  • web中如何解决文件上传取不到真实路径问题
    这篇文章主要为大家展示了“web中如何解决文件上传取不到真实路径问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“web中如何解决文件上传取不到真实路径问题”这...
    99+
    2022-10-19
  • 如何解决vue-router在同一个路由下切换,取不到变化的路由参数问题
    小编给大家分享一下如何解决vue-router在同一个路由下切换,取不到变化的路由参数问题,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!最近用vue写项目的时候碰到一个问题,在同一个页面下...
    99+
    2022-10-19
  • 在js中如何解决ng-repeat产生的ng-model中取不到值的问题
    小编给大家分享一下在js中如何解决ng-repeat产生的ng-model中取不到值的问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解...
    99+
    2022-10-19
  • Excel数据导入Mysql常见问题汇总:如何解决导入过程中遇到的数据校验问题?
    Excel数据导入Mysql常见问题汇总:如何解决导入过程中遇到的数据校验问题?导入Excel数据到MySQL数据库是我们在数据处理工作中经常需要进行的操作。然而,在这个过程中常常会遇到一些数据校验问题,导致导入失败或者导入后的数据不符合我...
    99+
    2023-10-22
    Excel导入 数据校验 Mysql常见问题
  • 如何解决使用php中mail函数发送邮件收不到的问题
    这篇文章主要介绍如何解决使用php中mail函数发送邮件收不到的问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!使用php中的mail函数发送邮件收不到的解决方法:首先安装sendmail和sendmail-cf包...
    99+
    2023-06-15
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作