mybatis报错There is no getter for property named ‘XXX‘ in ‘class java.lang.String‘ 解决办法

1、问题背景
在使用mybatis查询时,报错There is no getter for property named ‘XXX’ in ‘class java.lang.String’ 错误
具体接口如下:

Page<User> findUserList(String queryString);
<select id="findUserList" parameterType="string" resultType="com.co.pojo.User">
        select * from t_user
        <if test="queryString != null">
            where code = #{queryString} or name = #{queryString}
        </if>
</select>

接口中我们定义了findUserList(String queryString),形参的名称为queryString。按理来说在sql里就用#{queryString}去获取。
2、原因
但是,不是这样的,这里的”参数名”可以是任意的。
因为JAVA反射只能获取方法参数的类型,但无从得知方法参数的名字的
3、解决方案
因此mybatis考虑到这点,提供了@param注解,我们只需在接口的方法参数前加上param注解就好了,如下:

Page<User> findUserList(@Param("queryString") String queryString);
  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

十一*

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值