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
相关推荐
只是一个关于java和Oracle的一个简单的模糊查询
oracle拼音首字母查询
oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具...
oracle 关于字符串中带有逗号间隔的查询 例如 我想查出dwdh中有“飞信”的内容(不包括移动飞信,飞信移动) 关于字符串中带有逗号间隔的查询 利用like
oracle锁表查询oracle锁表查询oracle锁表查询oracle锁表查询
突然想到Oracle有一个编码转换的函数叫Convert,如果一个字符串编码转换前后不一样表示字符串里面含有非ASCII字符,这样得到结果。后写出来测试了一下,确实可行,5500万记录10秒钟扫描结束。以下是测试用例: ...
主要介绍了Mybatis 中 Oracle 的拼接模糊查询及用法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
oracle_11gR2_08 分组查询GROUP BY,模糊查询LIKE
分页查询是Oracle数据库比较重要的一个知识点!希望这个对你有参照作用。
oracle树状结构查询即层次递归查询,是sql语句经常用到的,在实际开发中组织结构实现及其层次化实现功能也是经常遇到的。这篇文章给大家介绍了Oracle递归树形结构查询功能,需要的朋友参考下
ssh框架实现的增删改查、模糊查询、上下翻页的功能,数据库是oracle,
ORACLE中SQL查询优化技术.pdf ORACLE中SQL查询优化技术.pdf
oracle查询用户信息1.查看所有用户2.查看用户或角色系统权限3.查看角色4.查看用户对象权限5.查看所有角色
oracle系统表查询,详细讲解各个系统表的使用
在用Oracle的时候查询不方便,网上找了这个,比较好用 Oracle数据查询,通用查询分析器
Oracle中应该避免将特殊字符@用于密码中,因为在Oracle中,@符号用来表明使用哪一台Oracle服务器。本文介绍了避免Oracle数据库的密码出现@符号的方法。
OracleOracle查询死锁表OracleOracle查询死锁表OracleOracle查询死锁表
Oracle中的树状查询(递归查询),权限查询,树形结构
oracle查询表碎片语句
select sysdate from dual 等等一些关于oracle的查询当前时间,日期的一些sql语句的