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>

去掉单引号即可

相关推荐
阿蒙Amon13 小时前
C#每日面试题-简述命名空间和程序集
java·面试·c#
烤麻辣烫13 小时前
Java开发手册规则精选
java·开发语言·学习
小宇的天下13 小时前
Virtuoso 中的tech file 详细说明
java·服务器·前端
WX-bisheyuange13 小时前
基于SpringBoot的诊疗预约平台
java·spring boot·后端·毕业设计
SimonKing13 小时前
基于Netty的WebSocket客户端
java·后端·程序员
ekkcole13 小时前
java实现对excel模版填充保存到本地后合并单元格并通过网络下载
java·开发语言·excel
Zoey的笔记本13 小时前
「软件开发缺陷管理工具」的闭环追踪设计与自动化集成架构
java·服务器·前端
麦兜*13 小时前
Spring Boot整合MyBatis-Plus实战:简化CRUD操作的最佳实践
spring boot·tomcat·mybatis
极客先躯13 小时前
高级java每日一道面试题-2025年5月09日-基础篇[协议-注解-缓存]-JCache(JSR-107)是什么?它的主要目标是什么?
java·spring·缓存
u01040583613 小时前
Java应用的链路追踪:实现分布式跟踪
java·开发语言·分布式