oracle中带有特殊符号的模糊查询
2012-11-06 18:31
381 查看
首先讲一下Oracle模糊查询
Oracle模糊查询可使用的通配符,Oralce中SQL语句提供了四种匹配模式:
% 零或者多个字符
_ 单一任何字符(下划线)
\ 特殊字符
[] 在某一范围内的字符,如[0-9]或者[aeth]
[^] 不在某范围内的字符,如[^0-9]或者[^aeth]
后两种, 需要Oracle 10g以上使用支持like的正则regexp_like
[ ]:表示括号内所列字符中的一个(类似正则表达式)。
指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个
如 [ ] 内有一系列字符(01234、abcde之类的)则可略写为“0-4”、“a-e”
[^ ] :表示不在括号所列之内的单个字符。其取值和 [] 相同,但它要求所匹配对象为指定字符以外的任一个字符。
注:oracle like 不支持正则,你可以使用支持like的正则regexp_like
select * from table_name where regexp_like(name,'[张李王]三');
由于通配符的缘故,导致我们如果想要查询包括这些特殊字符的内容“%”、“_”、“[”的语句无法正常实现
oracle中的模糊查询,带有特殊符号
用like语句查询的话可以,但是有特殊符号的话不能识别,如:#,%,_等
第一种方法:
可以用 regexp_like(字段名 ,'带有特殊符号的模糊字')这个查询
例如:
select * from user_souce t
where to_char(t.us_time, 'yyyymmdd') = '20120615' and regexp_like(t.us_from, 'hello[Mr.hailey]');
第二种方法:转义特殊字符,转义符可以自己定义,用escape '转义符'定义即可
例如:
-- 查找所有包含'_'的
select * from emp where ename like '%?_%' escape '?'; --转义符为问号?
select * from emp where ename like '%/_' escape '/'; --转义符为斜杠/
--查找所有以_结尾的
select * from emp where ename like '%\_' escape '\'; --转义符为反斜杠\
同理,通过这种方法查找含有'%'的所有字段:
select * from emp where ename like '%\%%' escape '\';
但是'&'不能通过转义字符查找
如果按上面的写法,
select * from emp where ename like '%\&' escape '\';
会提示:ORA-01424: 转义符之后字符缺失或非法
可以通过另外的方式进行转义:
select ascii('&') from dual;
ASCII('&')
----------
38
select * from emp where ename like '%' || chr(38) || '%';
在oracle中chr()函数和ascii()是一对反函数
chr()函数将ASCII码转换为字符:ASCII码 --> 字符
ascii('字符')函数获得该字符的ascii码值,将字符转换为ASCII码:字符 --> ASCII码
但是,注意%不能用这种方法转义(%号的ascii码为37)因为转出来还是一个%号,还是会当做通配符找出所有的数据
--单引号的转义
如果按上面的写法,
select * from emp where ename like '%\'%' escape '\';
会提示:ORA-01756:引号内的字符串没有正确结束,因为不能正确识别结束
--查找所有含有单引号的名字
select * from emp where ename like '%''%';
Oracle模糊查询可使用的通配符,Oralce中SQL语句提供了四种匹配模式:
% 零或者多个字符
_ 单一任何字符(下划线)
\ 特殊字符
[] 在某一范围内的字符,如[0-9]或者[aeth]
[^] 不在某范围内的字符,如[^0-9]或者[^aeth]
后两种, 需要Oracle 10g以上使用支持like的正则regexp_like
[ ]:表示括号内所列字符中的一个(类似正则表达式)。
指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个
如 [ ] 内有一系列字符(01234、abcde之类的)则可略写为“0-4”、“a-e”
[^ ] :表示不在括号所列之内的单个字符。其取值和 [] 相同,但它要求所匹配对象为指定字符以外的任一个字符。
注:oracle like 不支持正则,你可以使用支持like的正则regexp_like
select * from table_name where regexp_like(name,'[张李王]三');
由于通配符的缘故,导致我们如果想要查询包括这些特殊字符的内容“%”、“_”、“[”的语句无法正常实现
oracle中的模糊查询,带有特殊符号
用like语句查询的话可以,但是有特殊符号的话不能识别,如:#,%,_等
第一种方法:
可以用 regexp_like(字段名 ,'带有特殊符号的模糊字')这个查询
例如:
select * from user_souce t
where to_char(t.us_time, 'yyyymmdd') = '20120615' and regexp_like(t.us_from, 'hello[Mr.hailey]');
第二种方法:转义特殊字符,转义符可以自己定义,用escape '转义符'定义即可
例如:
-- 查找所有包含'_'的
select * from emp where ename like '%?_%' escape '?'; --转义符为问号?
select * from emp where ename like '%/_' escape '/'; --转义符为斜杠/
--查找所有以_结尾的
select * from emp where ename like '%\_' escape '\'; --转义符为反斜杠\
同理,通过这种方法查找含有'%'的所有字段:
select * from emp where ename like '%\%%' escape '\';
但是'&'不能通过转义字符查找
如果按上面的写法,
select * from emp where ename like '%\&' escape '\';
会提示:ORA-01424: 转义符之后字符缺失或非法
可以通过另外的方式进行转义:
select ascii('&') from dual;
ASCII('&')
----------
38
select * from emp where ename like '%' || chr(38) || '%';
在oracle中chr()函数和ascii()是一对反函数
chr()函数将ASCII码转换为字符:ASCII码 --> 字符
ascii('字符')函数获得该字符的ascii码值,将字符转换为ASCII码:字符 --> ASCII码
但是,注意%不能用这种方法转义(%号的ascii码为37)因为转出来还是一个%号,还是会当做通配符找出所有的数据
--单引号的转义
如果按上面的写法,
select * from emp where ename like '%\'%' escape '\';
会提示:ORA-01756:引号内的字符串没有正确结束,因为不能正确识别结束
--查找所有含有单引号的名字
select * from emp where ename like '%''%';
相关文章推荐
- oracle中带有特殊符号的模糊查询
- oracle中带有特殊符号的模糊查询
- 【模糊查询】oracle中带有特殊符号的模糊查询
- oracle中带有特殊符号的模糊查询
- oracle中带有特殊符号的模糊查询
- 模糊查询中带有特殊符号的处理问题(如:+ - 等)
- oracle sql模糊查询时允许查询特殊字符
- mybatis 特殊符号转义和模糊查询和批量插入
- Oracle 特殊字符模糊查询的方法
- oracle Like模糊查询与带有关键字Reverse的索引应用
- 遇到拼接SQL 模糊查询 用户输入特殊符号出现的错误
- oracle sql模糊查询时允许查询特殊字符
- oracle中特殊字符的模糊查询
- 特殊符号模糊查询 sql
- sybase sql里面特殊符号的匹配和模糊查询:
- Oracle 特殊字符模糊查询的方法
- Oracle 特殊字符模糊查询的方法
- SSH+Oracle错误之4 问题真是接踵而至,,关于HQL的模糊查询 from TCdb c where c.mid like ‘_’
- Oracle用户密码使用特殊符号,例如&(AND)、$(Dollar)、#(Pound)、*(Star)等
- mysql模糊查询匹配特殊字符