SQL模糊查询时特殊字符的处理方式总结

当编写WHERE语句中有LIKE条件时,如果参数中需要匹配 % 和_ 等特殊字符时,必须进行处理,否则系统会将其当成通配符处理。
 
SqlServer:
有两种方案
一:将参数中的 [ 替换成 [[],  % 替换成 [%], _ 替换成 [_];(推荐用这种方案处理)
二:先将参数中的 \ 替换成 \\, [替换成\[ , % 替换成 \%, _ 替换成 \_;
然后在每个需要like查询的字段后加上escape '\'。
注:sqlserver2005测试通过
 
Oracle只能既改参数,又改SQL语句。
先将参数中的 \ 替换成 \\,  % 替换成 \%, _ 替换成 \_;
然后在每个需要like查询的字段后加上escape   chr(92   USING   NCHAR_CS),组成的SQL语句形如:
select * from A where name like '%\%%' escape chr(92 USING NCHAR_CS) or addr like '%\_%' escape chr(92 USING NCHAR_CS);
在ORACLE 9I中必须写escape chr(92 USING NCHAR_CS)这么长一段,ORACLE 10G中可以简写成escape '\'
注:oracle9i、10g测试通过
 
Mysql的情况与ORACLE类似,也需要用escape语句。但是经测试不能用escape '\',所以用escape '/'
先将参数中 / 替换成 //,% 替换成 /%,_ 替换成 /_,\ 替换成 /\;
然后在每个需要like查询的字段后加上escape '/'。
注:Mysql 5.5测试通过
 
Access不能用escape,但与SQLSERVER类似,只需将参数中的 [ 替换成 [[],  % 替换成 [%], _ 替换成 [_]即可。
注:Access2003测试通过

posted on   小小娟  阅读(16349)  评论(2编辑  收藏  举报

编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?

导航

< 2011年9月 >
28 29 30 31 1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30 1
2 3 4 5 6 7 8
点击右上角即可分享
微信分享提示