mybatis中Parameter index out of range (1 > number of parameters, which is 0).
链接地址[2024 Java面试题整理https://pan.quark.cn/s/1c2bc87f7ec7]
Parameter index out of range (1 > number of parameters, which is 0).(参数索引超出范围)
在mybatis里面写就是应该是 like '%${name} %' 而不是 '%#{name} %'
${name} 是不带单引号的,而#{name} 是带单引号的
所以,当你用到 like '%#{name}%' 会报这种错误
----------------------------------更新 20181114-------------------------
但是${name} 是会存在SQL注入问题,首先感谢 @ TeddyXiong 同学的告知
对于这种情况,可以采用mysql 语法 CONCAT
例如: CONCAT('%',#{name},'%')
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· DeepSeek 解答了困扰我五年的技术问题
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 实操Deepseek接入个人知识库
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· 易语言 —— 开山篇