首页 > 数据库 >ORACLE-【模糊查询】oracle中带有特殊符号的模糊查询

ORACLE-【模糊查询】oracle中带有特殊符号的模糊查询

时间:2023-09-16 16:15:19浏览次数:37  
标签:字符 like -- 模糊 查询 转义 特殊符号 hello liketesttable

首先讲一下Oracle模糊查询,模糊查询使用的是like关键字

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,'[张李王]三');
查询name值为张三,李三,王三的记录,及[张李王]其中一个字符和'三'匹配;

--创建测试表:

create table LIKETESTTABLE
(
ID NUMBER not null,
NAME VARCHAR2(100),
CONTENT CLOB,
TITLE VARCHAR2(200),
FORMS VARCHAR2(200)
)

--插入测试数据:
insert into liketesttable (ID, NAME, CONTENT, TITLE, FORMS)
values (1, '张三', '<CLOB>', '明天_天气不错', 'hello#ggg');
insert into liketesttable (ID, NAME, CONTENT, TITLE, FORMS)
values (2, '王三', '<CLOB>', '明天_天气不错', 'hello*ffdd');
insert into liketesttable (ID, NAME, CONTENT, TITLE, FORMS)
values (3, '李三', '<CLOB>', '明天_天气不错', 'hello$ddd');
insert into liketesttable (ID, NAME, CONTENT, TITLE, FORMS)
values (4, '李四', '<CLOB>', '明天_天气不错', 'hello@ddd');
insert into liketesttable (ID, NAME, CONTENT, TITLE, FORMS)
values (6, '王八', '<CLOB>', '明天_天气不错', 'hello_ggg');
insert into liketesttable (ID, NAME, CONTENT, TITLE, FORMS)
values (7, '舅舅', '<CLOB>', '明天_天气不错', 'hello_ffffff');
insert into liketesttable (ID, NAME, CONTENT, TITLE, FORMS)
values (5, '王五', '<CLOB>', '明天_天气不错', 'hello~ddd');
注意clob是大字段,这里显示不出来,真实数据自己添加;

oracle中的模糊查询,带有特殊符号
用like语句查询的话可以,但是有特殊符号的话不能识别,如:#,%,_ 等

第一种方法:
可以用 regexp_like(字段名 ,'带有特殊符号的模糊字') 这个查询
例如:

select * from liketesttable where regexp_like(forms,'hello[_]')
输出结果:
ID NAME CONTENT TITLE FORMS
1 6 王八 明天_天气不错 hello_ggg
2 7 舅舅 明天_天气不错 hello_ffffff

hello[_]就是我们输入的参数,它会查找和name中值匹配的数据记录,hello[_]中包含了特殊的字符“#”;

如果是使用普通的模糊查询:

select *from liketesttable where forms like 'hello_%'

输出结果:

ID NAME CONTENT TITLE FORMS
1 1 张三 明天_天气不错 hello#ggg
2 2 王三 明天_天气不错 hello*ffdd
3 3 李三 明天_天气不错 hello$ddd
4 4 李四 明天_天气不错 hello@ddd
5 6 王八 明天_天气不错 hello_ggg
6 7 舅舅 明天_天气不错 hello_ffffff
7 5 王五 明天_天气不错 hello~ddd
因为“_”与(通配符“_”代表一个字符)冲突了,所以hello_%查出了所以结果;

第二种方法:转义特殊字符,转义符可以自己定义,用(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 '\';

改写第一种查询方法:sql:
select * from liketesttable where forms like '%\_%' escape '\';
输出结果:
ID NAME CONTENT TITLE FORMS
1 6 王八 明天_天气不错 hello_ggg
2 7 舅舅 明天_天气不错 hello_ffffff


但 是'&'不能通过转义字符查找
如果按上面的写法,
select * from liketesttable where forms like 'hello\&%' escape '\';
会提示:ORA-01424: 转义符之后字符缺失或非法
可以通过另外的方式进行转义:
select ascii('&') from dual;
ASCII('&')
----------
38

正确写法:
select *from liketesttable where forms like 'hello'|| chr(38) ||'%'
在oracle中chr()函数和ascii()是一对反函数
chr()函数将ASCII码转换为字符:ASCII码 --> 字符
ascii('字符')函数获得该字符的ascii码值,将字符转换为ASCII码:字符 --> ASCII码

但是,注意%不能用这种方法转义(%号的ascii码为37)因为转出来还是一个%号,还是会当做通配符找出所有的数据;


--单引号的转义
如果按上面的写法,

select * from liketesttable where forms like 'hello\'%' escape '\';

会提示:ORA-01756:引号内的字符串没有正确结束,因为不能正确识别结束
--查找所有含有单引号的名字
select *from liketesttable where forms like 'hello''%'

单引号的转义可以参考:
http://wjlvivid.iteye.com/blog/1684535


附:

转义和不转义:
转义:like 'DB\_Design'-->查的是'DB_Design'这个字符串,只有这个符合;
不转义:like 'DB_Design'-->查的是所有符合'DB_Design'的字符串“_”代表一个字符,可以是任意的字符,例如'DBFDesign','DBHDesign','DByDesign'都符合;
转义就是将特殊的字符变成一个普通的字符;
————————————————
版权声明:本文为CSDN博主「muzi1314_」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/muzi1314_/article/details/53692985

标签:字符,like,--,模糊,查询,转义,特殊符号,hello,liketesttable
From: https://www.cnblogs.com/turnip/p/17706850.html

相关文章

  • SQL——数据操纵语言DML(INSERT,UPDATE,DELETE)、数据查询语言DQL(SELECT)、操作符
     DML数据操纵语言(DataManipulationLanguage,DML),是指在SQL语言中,负责对数据库对象运行数据访问工作的指令集,以INSERT、UPDATE、DELETE三种指令为核心,分别代表插入、更新与删除,是开发以数据为中心的应用程序必定会使用到的指令。INSERT插入INSERT是将数据插入到数据库对象中的指令,......
  • 查询并交差运算
           ......
  • 一般子查询
         ......
  • 投影查询
        ......
  • 选择查询
         ......
  • 排序查询
      ......
  • 基于JAVA的即时空教室查询小程序
    互联网发展至今,无论是其理论还是技术都已经成熟,而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播,搭配信息管理工具可以很好地为人们提供服务。针对高校教师成果信息管理混乱,出错率高,信息安全性差,劳动强度大,费时费力等问题,采用即时空教室查询小程序可以有效管理,使信息......
  • 如何使用透明的div实现页面背景模糊效果
    要在页面背景上实现模糊效果,并使内容区域(<div>)保持半透明,你可以使用CSS的backdrop-filter属性。这个属性可以用于设置页面背景的滤镜效果,而不影响内部内容的模糊。下面是一个示例的代码片段,展示如何实现这个效果:<!DOCTYPEhtml><html><head><title>背景模糊效果</title>......
  • 设计查询学习记录接口
        ......
  • MySQL实战实战系列 01 基础架构:一条SQL查询语句是如何执行的?
    这是专栏的第一篇文章,我想来跟你聊聊MySQL的基础架构。我们经常说,看一个事儿千万不要直接陷入细节里,你应该先鸟瞰其全貌,这样能够帮助你从高维度理解问题。同样,对于MySQL的学习也是这样。平时我们使用数据库,看到的通常都是一个整体。比如,你有个最简单的表,表里只有一个ID......