我是靠谱客的博主 勤奋睫毛膏,最近开发中收集的这篇文章主要介绍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测试通过

转载于:https://www.cnblogs.com/jintianhu/archive/2011/09/23/2186664.html

最后

以上就是勤奋睫毛膏为你收集整理的SQL模糊查询时特殊字符的处理方式总结的全部内容,希望文章能够帮你解决SQL模糊查询时特殊字符的处理方式总结所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(35)

评论列表共有 0 条评论

立即
投稿
返回
顶部