您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

oracle中带有特殊符号的模糊查询

2026/1/1 3:27:42发布26次查看
首先讲一下oracle模糊查询 oracle模糊查询可使用的 通配符 ,oralce中sql语句提供了 四种匹配模式 : % 零或者多个字符 _ 单一任何字符(下划线) \ 特殊字符 [] 在某一范围内的字符,如[0-9]或者[aeth] [^] 不在某范围内的字符,如[^0-9]或者[^aeth] 后两种
首先讲一下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 '%''%';
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product