LIKE模糊查询

任何一个后端开发人员都写过模糊查询的方法(当然包括猿Why)……
后端会有这样几个过程:
从前端接收查询条件参数,例如:conditionA,conditionB

selectByLike(String conditionA,String conditionB);

通过持久层、SQL预编译等步骤,就会有这样的SQL语句:

SELECT   d.fieldA, d.fieldB, d.fieldC FROM DEMOTABLE d where d.fieldA LIKE ? AND  d.fieldB LIKE ?

那么,关于参数的处理,一般都是在后端代码中处理的,比如

// 左右均模糊
String.formatter("%%%s%%",conditionA);
// 只模糊右边(数据库表中某一列,如果需要添加索引,特别不建议在左边也进行模糊)
String.formatter("%s%%",conditionB);

最后方法调用的效果几乎是这样的

selectByLike(String.formatter("%%%s%%",conditionA),String.formatter("%s%%",conditionB));

以上呢就是常规操作,但是有一小缺陷:
如果我conditionA的值为"some_thing",那么最后的查询结果会匹配到some[此处可以是任意一个字符]thing,
当然,’%’、’'这些自字符可能也会引起开发人员的不适。
我的解决办法呢?

conditionA.replaceAll("_","/_").replaceAll("%","/%");

并且在SQL语句LIKE字段append escape ‘/’,(关于escape的介绍)SQL预编译出来的效果:

SELECT   d.fieldA, d.fieldB, d.fieldC FROM DEMOTABLE d where d.fieldA LIKE ? escape '/' AND  d.fieldB LIKE ? escape '/'

需要补充一下:escape 作用范围,仅仅是在一个like条件之后的,并不是整个where之后出现的like都作用。

遇到这种情况,猿Why可以想到这样的办法来解决,如果guru有更好的解决方案,请赐教!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值