概述
当编写WHERE语句中有LIKE条件时,如果参数中需要匹配 % 和_ 等特殊字符时,必须进行处理,否则系统会将其当成通配符处理。
SqlServer:
有两种方案
一:将参数中的 [ 替换成 [[], % 替换成 [%], _ 替换成 [_];(推荐用这种方案处理)
二:先将参数中的 替换成 \, [替换成[ , % 替换成 %, _ 替换成 _;
然后在每个需要like查询的字段后加上escape ''。
注:sqlserver2005测试通过
注: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测试通过
注:oracle9i、10g测试通过
Mysql的情况与ORACLE类似,也需要用escape语句。但是经测试不能用escape '',所以用escape '/'
先将参数中 / 替换成 //,% 替换成 /%,_ 替换成 /_, 替换成 /;
先将参数中 / 替换成 //,% 替换成 /%,_ 替换成 /_, 替换成 /;
然后在每个需要like查询的字段后加上escape '/'。
注:Mysql 5.5测试通过
注:Mysql 5.5测试通过
Access不能用escape,但与SQLSERVER类似,只需将参数中的 [ 替换成 [[], % 替换成 [%], _ 替换成 [_]即可。
注:Access2003测试通过
注:Access2003测试通过
转载于:https://www.cnblogs.com/jintianhu/archive/2011/09/23/2186664.html
最后
以上就是勤奋睫毛膏为你收集整理的SQL模糊查询时特殊字符的处理方式总结的全部内容,希望文章能够帮你解决SQL模糊查询时特殊字符的处理方式总结所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复