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

jintianhu2000 2011-09-23 09:02:22
当编写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测试通过
...全文
807 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
feng84131421 2011-09-24
  • 打赏
  • 举报
回复
mark
迈克尔1998 2011-09-24
  • 打赏
  • 举报
回复
hehe
nkhuangyanping 2011-09-24
  • 打赏
  • 举报
回复
来看看,支持楼主。
萧炎 2011-09-24
  • 打赏
  • 举报
回复
来点人 结贴

想发个帖子收集资料供大家参考 结果呢。。。。 太失望了 大家速去去 人齐结贴

诺维斯基 2011-09-24
  • 打赏
  • 举报
回复
暖枫无敌 2011-09-24
  • 打赏
  • 举报
回复
PPMMOOT 2011-09-24
  • 打赏
  • 举报
回复
嗯,如果有需要转义的字符一般都用"/"转义
LMAOhuaNL 2011-09-24
  • 打赏
  • 举报
回复
不错,哥们,值得关注的

110,567

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧