sql like 通配符及特殊字符的模糊查询处理

转载 2018年02月08日 10:38:32
当编写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测试通过

sql like 通配符 模糊查询技巧及特殊字符

1,SQL like对时间查询的处理方法 SQL数据表中有savetime(smalldatetime类型)字段,表中有两条记录,savetime值为:2005-3-8 12:12:00和2005-...
  • xiaojian1018
  • xiaojian1018
  • 2015年07月13日 09:04
  • 1812

[转]sql like 通配符 模糊查询技巧及特殊字符

                                                                                                    ...
  • Lisliefor
  • Lisliefor
  • 2011年06月16日 10:28
  • 10725

like查询特殊字符,用转义符处理

like中查询的字符串中有特殊字符,如:'_','%'该怎么查询。 理论 Oracle数据库中escape用来定义转义符,在转义符后加一个通配符,表示将该通配符变为普通字符。e...
  • windsna
  • windsna
  • 2014年08月13日 14:40
  • 2587

Mybatis解决sql中like通配符模糊匹配

针对oracle数据库: 1、将查询条件通过功能类处理 /** * Description: 处理转义字符%和_,针对ORACLE数据库 * * @param str * @re...
  • kpchen_0508
  • kpchen_0508
  • 2015年09月16日 16:55
  • 2790

ACCESS模糊查询like的解决方法&&SQL查询语句通配符问题

前言:ACCESS的通配符和SQL SERVER的通配符比较===================================================ACCESS库的通配符为: *  与任...
  • linuxyz85
  • linuxyz85
  • 2007年05月02日 12:17
  • 5653

sybase sql里面特殊符号的匹配和模糊查询:

sybase数据库支持的处理函数不是很多,但有些查询可以通过一些特殊的通配符来完成,比如: 数据库中有一个记录为varchar类型,字段内容是通过一个特殊符号char(65533)来链接的两部分内容...
  • liu76xt
  • liu76xt
  • 2014年03月19日 09:37
  • 2383

sql搜索like通配符的用法详解

有很多朋友写了几年的like搜索,可能对like后面通配符的用法都不了解,甚至于%的作用是什么都不清楚。在这篇文章中,我们就一起来学习一下like查询中通配符的用法吧。 我们写的最多的查询语句可...
  • qk5200
  • qk5200
  • 2013年08月06日 10:33
  • 3094

SQL Like 通配符

 SQL 通配符在搜索数据库中的数据时,SQL 通配符可以替代一个或多个字符。SQL 通配符必须与 LIKE 运算符一起使用。在 SQL 中,可使用以下通配符:通配符描述%替代一个或多个字符_仅替代一...
  • xushichang
  • xushichang
  • 2009年08月01日 10:23
  • 32262

Mysql| 使用通配符进行模糊查询(like,%,_)

通配符的分类: %百分号通配符: 表示任何字符出现任意次数(可以是0次). _下划线通配符:表示只能匹配单个字符,不能多也不能少,就是一个字符.like操作符: LIKE作用是指示mysql后面...
  • u011479200
  • u011479200
  • 2017年11月12日 18:39
  • 308

sql特殊字符的模糊查询处理

// 判断模糊查询字符中是否含有%,如果有全部转义成\% if (!StringUtil.isEmpty(memberListBean.getPhoneOrNumber())) { Stri...
  • qq_34707991
  • qq_34707991
  • 2017年11月14日 15:34
  • 37
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:sql like 通配符及特殊字符的模糊查询处理
举报原因:
原因补充:

(最多只允许输入30个字)