oracle 特殊字符处理

如果你手头的某个项目或产品有模糊搜索的功能,建议你做个测试: 
在搜索框中输入:“_”(下划线)或者“%”(百分号),然后进行搜索,看看会得到什么结果。 
如果你的搜索结果与预期一致,即只搜到含“_”或“%”的结果,那么恭喜你,你没有掉到这个陷阱中去,尽管你自己可能根本没意识到为什么。 
如果你的搜索结果出现了很多根本不含任何“_”或“%”的结果,那说明你跟我一样,根本就没考虑过这个问题,这也正是本文要解决的问题。 
其实这个问题说也简单,因为我们绝大多数搜索都是基于SQL的,其中的模糊搜索应该大多数人都知道,就是: 
LIKE %XX%,其中%代表任意长度的字符串,跟我们常用的通配符“*”作用类似。除了"%"比较常用外,还有一个可能很多人不知道的通配符:“_”, 
其作用跟常见的通配符“?”作用类似。基于以上原因,如果你不做任何处理,直接搜索包含着两个特殊字符的关键词是不可能得到正确结果的。 
例如,如果直接输入%或_搜索,得到的是所有结果集合。 
难道就没有办法搜索这种特殊字符吗?办法当然是有的,那就是用‘escape’这个鲜为人知的关键词, 
例如可以用下面的语句: 




Sql代码  
1.Select * from demo_table where keyword like '^%' escape '^' ;  



这里'^'本来是个普通字符,但经过escape之后,它就变成了一个转义符,在它之后的%就被它转义为一个普通字符了。这样就可以进行对特殊字符的查询了。 
也许有人会说,我根本没有考虑过这个问题,但我的系统能够正常查询,这是为什么呢? 
这是因为你依赖的后台系统已经替你考虑了。比如hibernate的criteria已经对此作了特殊封装,有兴趣的可以看看它的LikeExpression类是如何处理的。 
而如果你用的不是hibernate,则需要自己亲自处理这个问题了。

猜你喜欢

转载自wb284551926.iteye.com/blog/1742827