bug场景记录

项目场景:

mapper.xml文件中sql语句执行失败,显示输入的参数数量不对

问题描述

sql 复制代码
 <select id="page" resultType="com.sky.entity.Employee">
        select * from employee
            <where>
                <if test="name != null and name !=''">
                    and name like concat('%','#{name}','%')
                </if>
            </where>
                 order by create_time desc
    </select>

xml文件出错

原因分析:

当name的输入为中文字符串时,例如 "标准" 二字会导致mybatis无法自动注入name

解决方案:

将xml文件中的sql语句修改为

sql 复制代码
 <select id="page" resultType="com.sky.entity.Employee">
        select * from employee
            <where>
                <if test="name != null and name !=''">
                    and name like concat('%',#{name},'%')
                </if>
            </where>
                 order by create_time desc
    </select>

去掉单引号即可

相关推荐
Henray202413 小时前
最低公共祖先 LCA
java·面试
shehuiyuelaiyuehao13 小时前
关于进程和线程的关系
java·开发语言
河阿里13 小时前
SpringBoot:项目启动速度深度优化
java·spring boot·后端
AaronCos14 小时前
弄懂java泛型中的extends和super
java·开发语言
用户2395261801014 小时前
别再 new 满天飞了!一文搞懂工厂模式,程序员终于不用手搓对象了 😆
java
阿丰资源14 小时前
基于SpringBoot的企业客户管理系统(附源码)
java·spring boot·后端
两年半的个人练习生^_^14 小时前
SpringBoot 项目使用 Jasypt 实现配置文件敏感信息加密
java·spring boot·后端
JAVA学习通14 小时前
开云集致 Java开发 实习 一面
java·开发语言
阿旭超级学得完14 小时前
C++11(初始化)
java·开发语言·数据结构·c++·算法
一只大袋鼠15 小时前
SpringMVC全局异常处理
java·开发语言·springmvc·javaweb