您的位置:首页 > 数据库 > Oracle

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 '%''%';
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: