【Oracle】3.模糊查询
2016-04-10 18:54
453 查看
概念
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
<span style="font-size:18px;"><span style="font-size:18px;">select * from table_name where regexp_like(name,'[张李王]三');</span></span>
由于通配符的缘故,导致我们如果想要查询包括这些特殊字符的内容“%”、“_”、“[”的语句无法正常实现
模糊查询
oracle中的模糊查询,带有特殊符号用like语句查询的话可以,但是有特殊符号的话不能识别,如:#,%,_ 等
第一种方法:
可以用 regexp_like(字段名 ,'带有特殊符号的模糊字') 这个查询
例:
<span style="font-size:18px;"><span style="font-size:18px;"><span style="font-size:18px;"><span style="font-size:18px;">select * from user_souce t where to_char(t.us_time, 'yyyymmdd') = '20160408' and regexp_like(t.us_from, 'hello[Mr.hailey]');</span></span></span></span>
第二种方法:转义特殊字符,转义符可以自己定义,用escape '转义符'定义即可
例:
-- 查找所有包含'_'的
<span style="font-size:18px;"><span style="font-size:18px;"><span style="font-size:18px;"><span style="font-size:18px;">select * from emp where ename like '%?_%' escape '?'; --转义符为问号? select * from emp where ename like '%/_' escape '/'; --转义符为斜杠/</span></span></span></span>--查找所有以_结尾的
<span style="font-size:18px;"><span style="font-size:18px;"><span style="font-size:18px;"><span style="font-size:18px;">select * from emp where ename like '%\_' escape '\'; --转义符为反斜杠\</span></span></span></span>
同理,通过这种方法查找含有'%'的所有字段:
<span style="font-size:18px;"><span style="font-size:18px;"><span style="font-size:18px;"><span style="font-size:18px;">select * from emp where ename like '%\%%' escape '\';</span></span></span></span>
但是'&'不能通过转义字符查找
如果按上面的写法,
<span style="font-size:18px;"><span style="font-size:18px;"><span style="font-size:18px;"><span style="font-size:18px;">select * from emp where ename like '%\&' escape '\'; </span></span></span></span>会提示:ORA-01424: 转义符之后字符缺失或非法
可以通过另外的方式进行转义:
<span style="font-size:18px;"><span style="font-size:18px;"><span style="font-size:18px;"><span style="font-size:18px;">select ascii('&') from dual; ASCII('&') ---------- 38 select * from emp where ename like '%' || chr(38) || '%';</span></span></span></span>
在oracle中chr()函数和ascii()是一对反函数
chr()函数将ASCII码转换为字符:ASCII码 --> 字符
ascii('字符')函数获得该字符的ascii码值,将字符转换为ASCII码:字符 --> ASCII码
但是,注意%不能用这种方法转义(%号的ascii码为37)因为转出来还是一个%号,还是会当做通配符找出所有的数据。
--单引号的转义
如果按上面的写法,
<span style="font-size:18px;"><span style="font-size:18px;">select * from emp where ename like '%\'%' escape '\';</span></span>会提示:ORA-01756:引号内的字符串没有正确结束,因为不能正确识别结束
--查找所有含有单引号的名字
<span style="font-size:18px;"><span style="font-size:18px;">select * from emp where ename like '%''%';</span></span>
--自定义的转义字符
<span style="font-size:18px;"><span style="font-size:18px;"><span style="font-size:18px;"><span style="font-size:18px;">select * from emp where ename like '%%%'; select * from emp where ename like '%\%%' escape '\' select * from emp where ename like '%W%%' escape 'W'; select ename from emp where ename like '%%'; 相当于 select * from emp where ename is not null;</span></span></span></span>
由于NULL为空值,不包含任何值,所以无法检测出来。
关于自定义的转移字符,可参照CSDN论坛讲述的来更好的理解。
业务思想
对于Oracle模糊查询的理解,可始于生活。当我们很熟悉一首歌的时候,我们只知道其中的一两句歌词,这时我们就要开始模糊查询了。而对于SQL来说,对于已知一部分内容的查询,我们也是使用模糊查询的。个人对于模糊插叙的理解目前只是这些,欢迎指点交流!
相关文章推荐
- 【Oracle】2.92与99语法差异化比较
- 【Oracle】1.安装和配置
- 谷歌希望让 Swift 成为安卓的优先选择,以取代由 Oracle 开发的 Java 程序语言。
- 读收获不止oracle--表设计有感
- 传说中的oracle的java证书这个样子!
- sqlldr入库Oracle
- Oracle--单行函数(字符函数、数字函数、日期函数、转换函数、通用函数)
- 怎样让oracle实验本在不做实验时性能提升——win7下举例
- oracle数据库乱码
- Oracle跨表空间导出导入数据
- Oracle 创建普通用户,并赋予权限
- oracle学习 第一章 简单的查询语句 ——03
- 分页数据有重复的问题
- 往Oracle数据库中插入日期型数据(to_date的用法)
- oracle学习 第一章 简单的查询语句 ——02
- 6、索引与索引组织表
- Oracle ,My SQL 与SQL Server的区别
- dual表
- oracle11g数据库安装和配置
- oracle operator:Quote&Escape