码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Mybatis的Mapper接口传递多个参数的时候必须要加@Param注解吗?


    答案是:不一定,取决于mybatis的版本、jdk的版本和javac的编译选项。

    测试代码

    Maven依赖:

    <dependency>
    	<groupId>org.mybatis.spring.bootgroupId>
    	<artifactId>mybatis-spring-boot-starterartifactId>
    	<version>2.3.1version>
    dependency>
    
    • 1
    • 2
    • 3
    • 4
    • 5

    依赖的mybatis的版本是3.5.13

    [INFO] +- org.mybatis.spring.boot:mybatis-spring-boot-starter:jar:2.3.1:compile
    [INFO] |  +- org.mybatis.spring.boot:mybatis-spring-boot-autoconfigure:jar:2.3.1:compile
    [INFO] |  +- org.mybatis:mybatis:jar:3.5.13:compile
    [INFO] |  \- org.mybatis:mybatis-spring:jar:2.1.1:compile
    
    • 1
    • 2
    • 3
    • 4

    Mapper接口:

    @Mapper
    public interface DeptMapper {
        @Select("select * from dept where name = #{name} and code = #{code}")
        List<Dept> selectByNameAndCode(String name, String code);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5

    junit test:

    @Test
       public void testSelectByNameAndCode() {
           List<Dept> depts = deptMapper.selectByNameAndCode("学工部", "XUEGONG");
           System.out.println(depts);
       }
    
    • 1
    • 2
    • 3
    • 4
    • 5

    能正常输出。

    原因解析

    查看mybatis的官方文档:
    在这里插入图片描述
    翻译一下:3.4.1之后提供了useActualParamName这个boolean的选项(默认是true),允许把接口方法的形参名作为mybatis语句的参数名,但是前提是项目需要用jdk8以上去编译并且需要添加编译选项-paramters。

    测试1)关闭useActualParamName

    mybatis:
      configuration:
        use-actual-param-name: false
    
    • 1
    • 2
    • 3

    再运行就会报错:

    org.mybatis.spring.MyBatisSystemException: 
    nested exception is org.apache.ibatis.binding.BindingException: 
    Parameter 'name' not found. Available parameters are [0, 1, param1, param2]
    
    • 1
    • 2
    • 3

    测试2)关闭编译选项-parameters
    idea->file->settings->compiler->java compiler
    在这里插入图片描述
    重新build项目,这样会重新编译class文件,再运行,依然报同样的错误。
    看下org.apache.ibatis.reflection.ParamNameResolver#ParamNameResolver这个方法的源代码就足够了。

    测试代码下载

    结论

    1)3.4.1之前,mapper接口传递多个参数的时候,必须要加@Param,不加就会报错。
    2)3.4.1之后不一定,如果是开启了useActualParamName参数(默认就是开启的),并且在源代码编译的时候加上了-parameters参数(idea默认就添加了这个参数)就不需要加@Param了,否则还是需要加@Param的。
    3)综上,建议还是加上吧。

  • 相关阅读:
    坚持自主创新 线控底盘领军企业英创汇智获数亿元B+轮融资
    Flutter 类似onResume 监听,解决入场动画卡顿(2)
    GTC大咖论坛:数字孪生工厂为啥势在必行
    Linux检查Docker镜像,容器的磁盘空间
    JAVA String API即StringBuilderAPI
    将时间序列转成图像——相对位置矩阵方法 Matlab实现
    使用DockerCompose部署Redis分片集群——整合SpringBoot
    TypeError: Cannot read properties of null (reading ‘insertBefore‘) vue项目报错
    【Vue】悬浮窗和聚焦登录组件经验总结
    大一作业HTML网页作业 HTML校园篮球网页作业(12个页面)
  • 原文地址:https://blog.csdn.net/goldenfish1919/article/details/134449954
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号