java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > MyBatis模糊查询报错

MyBatis模糊查询报错:ParserException: not supported.pos 问题解决

作者:很少更新

本文主要介绍了MyBatis模糊查询报错:ParserException: not supported.pos 问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

问题描述

在使用MyBatis执行如下SQL时出现Druid解析异常:

 <select id="selectListMzHairVoById" resultMap="MzPinHairMap">
  select ... where pin_no like "%"#{id}"%"
  </select>

报错信息:

log merge sql error, dbType mysql, druid-1.2.9, sql : ... like '%'?'%' com.alibaba.druid.sql.parser.ParserException: not supported.pos 155...

问题根源

错误SQL解析逻辑

MyBatis会将 "%\"#{id}\"%" 解析为:

sql WHERE pin_no LIKE '%'?'%'

导致参数占位符被单引号包裹,MySQL无法识别这种语法结构

深层原因分析

三种解决方案

方案一:使用CONCAT函数(推荐)

<select id="selectListMzHairVoById" resultMap="MzPinHairMap"> 
SELECT ... 
WHERE pin_no LIKE CONCAT('%', #{id}, '%') 
</select>

优势

方案二:bind标签绑定参数

<select id="selectListMzHairVoById" resultMap="MzPinHairMap"> 
<bind name="pattern" value="'%' + id + '%'"/> 
SELECT ... WHERE pin_no LIKE #{pattern} 
</select>

适用场景:需要动态构造复杂匹配模式时使用

方案三:Java端预拼接参数

Service层:

public List<MzPinHairVo> query(String id) { 
String searchParam = "%" + id + "%"; 
return mapper.selectListMzHairVoById(searchParam);
 }

Mapper.xml:

<select id="selectListMzHairVoById" resultMap="MzPinHairMap">
 SELECT ... 
 WHERE pin_no LIKE #{id}
  </select>

注意事项:需确保参数来源可信,防止SQL注入

方案对比

方案安全性可维护性性能跨数据库兼容性
CONCAT★★★★★★★★★★★★
bind标签★★★★★☆★★☆★★★
Java拼接★★☆★☆☆★★★★★★

到此这篇关于MyBatis模糊查询报错:ParserException: not supported.pos 问题解决的文章就介绍到这了,更多相关MyBatis模糊查询报错内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

您可能感兴趣的文章:
阅读全文