MyabtisPlus下划线通配符问题原因及解决方案

问题

项目中有这么一个查询:

SELECT
	p.PROJECT_NO AS idNo 
FROM
	project_execute e
	LEFT JOIN project p ON e.project_id = p.ID_NO 
WHERE
	p.PROJECT_NO LIKE CONCAT( '%', '_22', '%')

是想要对project表的PROJECT_NO字段进行一个模糊匹配,查询出含有_22的数据,但是查询结果确可以查询出任何包含22这个字符的数据,_下划线没有起到作用

问题原因

这是因为在MySQL的LIKE语句中,下划线_是一个通配符,可以匹配任意单个字符。
所以当查询LIKE '%_22%'时会匹配到包含任意单个字符+22+任意单个字符的字符串。

解决方案

如果项目和我一样使用的是MybatisPlus框架,可以新增一个config重写ConfigurationCustomizer接口中的customize()方法,重写了 setNonNullParameter 方法,对查询参数中的下划线 _ 进行转义处理,将其替换为 \_,以避免被解析为通配符。然后调用父类的 setNonNullParameter 方法将转义后的参数设置到 PreparedStatement 中。具体如下:

@Configuration
public class MyBatisPlusConfig implements ConfigurationCustomizer {
    @Override
    public void customize(MybatisConfiguration configuration) {
        configuration.getTypeHandlerRegistry().register(String.class, new StringTypeHandler() {
            @Override
            public void setNonNullParameter(PreparedStatement ps, int i, String parameter, JdbcType jdbcType) throws SQLException {
                if (parameter.contains("_")) {
                    parameter = parameter.replace("_", "\\_");
                }
                super.setNonNullParameter(ps, i, parameter, jdbcType);
            }
        });
    }
}

此时观察日志,打印的sql为:

SELECT
	p.PROJECT_NO AS idNo 
FROM
	project_execute e
	LEFT JOIN project p ON e.project_id = p.ID_NO 
WHERE
	p.PROJECT_NO LIKE CONCAT( '%', '/_22', '%')
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值