用MyBatis进行查询,传入参数只有一个时(非Map)如int,报错
There is no getter for property named 'sleevetype' in 'class java.lang.Integer
解决方法一:
原因在于测试条件写法有误,
<if test="sleevetype==0"><!-- 专属 --> exclusive=1 </if> <if test="sleevetype!=0"><!-- 非专属 --> sleeve_type=#{sleevetype} and exclusive=0 </if>
正确写法:
<if test="_parameter==0"><!-- 专属 --> exclusive=1 </if> <if test="_parameter!=0"><!-- 非专属 --> sleeve_type=#{sleevetype} and exclusive=0 </if>
不管传的参数是什么,都要改成"_parameter" 。
解决方法二:
是在DAO接口声明部分在形参前加上 @Param("sleevetype")
实际上,当DAO接口有多个参数时,需要使用@Param,或者用Map,或者对象。