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},'%')

 

posted @   码路编程  阅读(20900)  评论(7编辑  收藏  举报
编辑推荐:
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· DeepSeek 解答了困扰我五年的技术问题
阅读排行:
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 实操Deepseek接入个人知识库
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· 易语言 —— 开山篇
点击右上角即可分享
微信分享提示