SQL模糊查询通配符_和%处理

下划线和百分号在sql模糊查询like语句中为特殊字符,分别可匹配1个字符和0到多个字符,如果需要真正查询特殊字符得转义,如like 'a\_b%' escape '\',将匹配前3个字符为a_b的所有记录。

1、PreparedStatement处理

普遍做法,拼sql时使用like ?,左模糊在查询条件字符串左侧添加%,右模糊在查询条件字符串右侧添加%,对特殊字符进行预先转义

condition = condition.replaceAll("_", "\\\\_");

condition = condition.replaceAll("%", "\\\\%");

ps.setString(idx, "%" + conditon + "%")

为什么replaceAll中需要使用4个\可参考jdk源码Matcher.appendReplacement方法。

专业做法,拼sql时使用like ? escape '\'(java中使用两个\\)

2、多数据库支持处理

在postgres中escape需要使用'\\'(java中使用四个\\)处理

3、其他思考

查找数据库是否有配置模糊查询的默认转义字符,搜索未果,可能关键字抽取有问题,试图在oracle的v$parameter中查找会话相关参数但是没有收获。


建议处理方式:在sql中like后添加escape,但是不对原始输入条件进行转换,用户可在查询条件中使用转义字符查询特殊字符也可以进行中间模糊查询,如输入'a%b','a\%b'。


转载于:https://my.oschina.net/h2do/blog/304421

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值