`

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

 
阅读更多

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

首先讲一下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 '%''%';

单引号的转义请见本人的另一篇文章“oralce里面的单引号转义”,详见:http://wjlvivid.iteye.com/blog/1684535

分享到:
评论

相关推荐

    oracle学习文档 笔记 全面 深刻 详细 通俗易懂 doc word格式 清晰 连接字符串

    其一、就业面广:全球前100强企业99家都在使用ORACLE相关技术,中国政府机构,大中型企事业单位都能有ORACLE技术的工程师岗位。 其二、技术层次深:如果期望进入IT服务或者产品公司(类似毕博、DELL、IBM等),...

    Oracle上课笔记0-45.txt

    - `to_char(sal, 'L99,999.9999')`: 将薪资转换为带有货币符号(如L)的字符串格式。 - `to_number('$12,444.99', '$99,999.99')`: 将货币格式的字符串转换为数字。 ### 7. 其他 - `set linesize 200`: 设置每行的...

    Oracle练习笔试大全

    //(函数to_number()求出这种薪水里带有特殊符号的) 44、select ename, sal*12 + nvl(comm,0) from emp; //(函数nvl() 求出员工的"年薪 + 提成(或奖金)问题") 45、select max(sal) from emp; // (函数max() 求出...

    Oracle学习笔记

    18. **数值转换**:`to_number('$1,250.00','$9,999,00')` 用于将带有货币符号的字符串转换为数值。 19. **聚合函数**:`sum`, `avg`, `count`, `max`, `min` 是常用的聚合函数,如`count(name)`计算非NULL的name...

    oracle基础知识

    - `column salary justify right format $99,999.99`: 将`salary`列右对齐,并设置为带有美元符号和千位分隔符的货币格式。 - `column start_date format a10 null 'Not Hired'`: 如果`start_date`为空,则显示`Not ...

    整理oracle笔记

    `(将薪水转换为带有美元符号的格式) - **日期转换**:使用`TO_DATE()`函数将字符串转换为日期。 - 示例:`SELECT ename, hiredate FROM emp WHERE hiredate > TO_DATE('1981-2-2012:33:33', 'YYYY-MM-DDHH24:MI:...

    Java开发实战1200例(第1卷).(清华出版.李钟尉.陈丹丹).part3

    实例073 根据标点符号对字符串进行分行 92 实例074 将字符串的每个字符进行倒序输出 94 实例075 获取字符串中汉字的个数 94 实例076 批量替换某一类字符串 95 实例077 把异常与错误信息显示到窗体中 97 实例078 从...

    2009达内SQL学习笔记

    set pause "please put an enter key" 且 set pause on:设置带有提示的分屏 oerr ora 904 :查看错误 set head off :去掉表头 set feed off :去掉表尾 保存在oracle数据库中的所有操作细节: spool ...

    MapServer Documentation

    - **如何创建带有填充和边框宽度的多边形**:通过 LAYER 和 STYLE 子项控制。 - **如何创建简单的抗锯齿线要素**:通过 STYLE 子项中的参数控制线条平滑度。 - **MapServer 支持哪些 OGC 规范**:支持 WMS、WFS、WCS...

    精髓Oralcle讲课笔记

    --(函数to_number()求出这种薪水里带有特殊符号的) 44、select ename, sal*12 + nvl(comm,0) from emp; --(函数nvl() 求出员工的"年薪 + 提成(或奖金)问题") 45、select max(sal) from emp; -- (函数max() 求出...

Global site tag (gtag.js) - Google Analytics