mybatis${}字符串标识符无效问题【bug修复】

问题:

执行${}sql的时候,报标识符无效的错误

代码:

mapper.xml文件中的sql如下:

select count(0) from ${tableName} where id =${id}

mapper.java

        int getCount(@Param("tableName") String tableName, @Param("id") String id);

        发现执行sql的时候,id是字符串,并没有识别为字符串因此报错。

        执行的时候,变成了:

                 select count(0) from t_test where id =111abcd

         id不是字符串了,所以报错标识符无效

解决方案

最终调用 方法的时候传参手动加了单引号才执行成功

int count = mapper.getCount(tableName,"'"+id+"'");

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值