日期:2014-05-16 浏览次数:20546 次
如果你手头的某个项目或产品有模糊搜索的功能,建议你做个测试:?
在搜索框中输入:“_”(下划线)或者“%”(百分号),然后进行搜索,看看会得到什么结果。?
如果你的搜索结果与预期一致,即只搜到含“_”或“%”的结果,那么恭喜你,你没有掉到这个陷阱中去,尽管你自己可能根本没意识到为什么。?
如果你的搜索结果出现了很多根本不含任何“_”或“%”的结果,那说明你跟我一样,根本就没考虑过这个问题,这也正是本文要解决的问题。?
其实这个问题说也简单,因为我们绝大多数搜索都是基于SQL的,其中的模糊搜索应该大多数人都知道,就是:?
LIKE %XX%,其中%代表任意长度的字符串,跟我们常用的通配符“*”作用类似。除了"%"比较常用外,还有一个可能很多人不知道的通配符:“_”,?
其作用跟常见的通配符“?”作用类似。基于以上原因,如果你不做任何处理,直接搜索包含着两个特殊字符的关键词是不可能得到正确结果的。?
例如,如果直接输入%或_搜索,得到的是所有结果集合。?
难道就没有办法搜索这种特殊字符吗?办法当然是有的,那就是用‘escape’这个鲜为人知的关键词,?
例如可以用下面的语句:?
Sql代码??
1.Select * from demo_table where keyword like '^%' escape '^' ;??
这里'^'本来是个普通字符,但经过escape之后,它就变成了一个转义符,在它之后的%就被它转义为一个普通字符了。这样就可以进行对特殊字符的查询了。?
也许有人会说,我根本没有考虑过这个问题,但我的系统能够正常查询,这是为什么呢??
这是因为你依赖的后台系统已经替你考虑了。比如hibernate的criteria已经对此作了特殊封装,有兴趣的可以看看它的LikeExpression类是如何处理的。?
而如果你用的不是hibernate,则需要自己亲自处理这个问题了。