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
相关推荐
其一、就业面广:全球前100强企业99家都在使用ORACLE相关技术,中国政府机构,大中型企事业单位都能有ORACLE技术的工程师岗位。 其二、技术层次深:如果期望进入IT服务或者产品公司(类似毕博、DELL、IBM等),...
- `to_char(sal, 'L99,999.9999')`: 将薪资转换为带有货币符号(如L)的字符串格式。 - `to_number('$12,444.99', '$99,999.99')`: 将货币格式的字符串转换为数字。 ### 7. 其他 - `set linesize 200`: 设置每行的...
//(函数to_number()求出这种薪水里带有特殊符号的) 44、select ename, sal*12 + nvl(comm,0) from emp; //(函数nvl() 求出员工的"年薪 + 提成(或奖金)问题") 45、select max(sal) from emp; // (函数max() 求出...
18. **数值转换**:`to_number('$1,250.00','$9,999,00')` 用于将带有货币符号的字符串转换为数值。 19. **聚合函数**:`sum`, `avg`, `count`, `max`, `min` 是常用的聚合函数,如`count(name)`计算非NULL的name...
- `column salary justify right format $99,999.99`: 将`salary`列右对齐,并设置为带有美元符号和千位分隔符的货币格式。 - `column start_date format a10 null 'Not Hired'`: 如果`start_date`为空,则显示`Not ...
`(将薪水转换为带有美元符号的格式) - **日期转换**:使用`TO_DATE()`函数将字符串转换为日期。 - 示例:`SELECT ename, hiredate FROM emp WHERE hiredate > TO_DATE('1981-2-2012:33:33', 'YYYY-MM-DDHH24:MI:...
实例073 根据标点符号对字符串进行分行 92 实例074 将字符串的每个字符进行倒序输出 94 实例075 获取字符串中汉字的个数 94 实例076 批量替换某一类字符串 95 实例077 把异常与错误信息显示到窗体中 97 实例078 从...
set pause "please put an enter key" 且 set pause on:设置带有提示的分屏 oerr ora 904 :查看错误 set head off :去掉表头 set feed off :去掉表尾 保存在oracle数据库中的所有操作细节: spool ...
- **如何创建带有填充和边框宽度的多边形**:通过 LAYER 和 STYLE 子项控制。 - **如何创建简单的抗锯齿线要素**:通过 STYLE 子项中的参数控制线条平滑度。 - **MapServer 支持哪些 OGC 规范**:支持 WMS、WFS、WCS...
--(函数to_number()求出这种薪水里带有特殊符号的) 44、select ename, sal*12 + nvl(comm,0) from emp; --(函数nvl() 求出员工的"年薪 + 提成(或奖金)问题") 45、select max(sal) from emp; -- (函数max() 求出...