一、mapper接口传参数的两大种方式
- 使用实体类、Map传参数,取值方式:#{实体类的属性名或键}
- 使用@Param传参数,取值方式:#{指定value值}
二、spring boot项目的mapper接口方法中多个参数时,不使用@Param,却能使用属性名取值
Java8新增编译参数-parameters,使得反射可以获取方法的参数名,Java8之前只能获取到,arg0、arg1等
其原因是mybatis的setting参数useActualParamName
设置名 | 描述 | 有效值 | 默认值 |
useActualParamName | 允许使用方法签名中的名称作为语句参数名称。 为了使用该特性,你的项目必须采用 Java 8 编译,并且加上 -parameters 选项。(新增于 3.4.1) | true 或者 false | true |
所以说这个属性其实就是允许我们使用mapper接口方法的参数名称当作sql语句的参数名称,而且也不需要@Param注解,这个属性默认是开启的,使用这个特性还有以下几个要求:
①采用 Java 8 编译。
②编译时加上-parameters 选项。
③mybatis在3.4.1以上
注意: 不满足要求时,不添加@Param注解,依旧会报错如下:
org.apache.ibatis.binding.BindingException: Parameter 'XXX' not found. Available parameters arAvailable parameters are [arg1, arg0, param1, param2]] with root cause
三、Eclipse/IDEA编辑器设定调整
eclipse:项目右键->点击Properties->点击java Compiler->勾选图中选项
IDEA: