SQL模糊查询时特殊字符的处理方式总结
2012-02-13 15:25
561 查看
当编写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测试通过
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测试通过
相关文章推荐
- SQL模糊查询时特殊字符的处理方式总结
- 基于hibernate的基本dao接口与实现 及 sql模糊查询特殊字符处理 及 struts 特殊字符在界面正常回显
- sql特殊字符的模糊查询处理
- SQL查询中的特殊字符的处理
- SQL查询中的特殊字符处理
- 实现模糊查询时对特殊字符进行处理和对查询结果进行处理
- 不同数据库模糊查询特殊字符处理
- oracle sql模糊查询时允许查询特殊字符
- 模糊查询某个字段除以100去查询,处理特殊字符和0值
- SQL的一些模糊查询特殊字符的转译
- sql语句中含有特殊字符的处理方式
- SqlServer中模糊查询对于特殊字符的处理方法
- oracle sql模糊查询时允许查询特殊字符
- 如何在SQL模糊查询中忽略对大小写字符的处理
- 实现模糊查询时对特殊字符进行处理和对查询结果进行处理
- SqlServer中模糊查询对于特殊字符的处理
- 关于处理SQL特殊字符的基本方法总结
- T-SQL---多值模糊查询的处理
- XML中特殊字符的处理方式
- sql语句中模糊查询Like中通配符的处理