【模糊查询】oracle中带有特殊符号的模糊查询_oracle模糊查询包含用什么符号表示_muzi1314_的博客-程序员宅基地

技术标签: oracle  Oracle  like 模糊查询  

首先讲一下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'都符合;
转义就是将特殊的字符变成一个普通的字符;





版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/muzi1314_/article/details/53692985

智能推荐

Flink 入门实战之六Source自定义读取mysql数据_mysqlsource flink-程序员宅基地

自定义Source连接mysql重写SourceRichFunction通过JDBC方式连接Mysql使用预执行语句执行带参数sql语句package com.dayimport java.sql.{Connection, DriverManager, PreparedStatement}import org.apache.flink.configuration.Configurationimport org.apache.flink.streaming.api.functions.so_mysqlsource flink

2011~2012-程序员宅基地

2011---C++ (复习)openClass (terminal)《数据结构》 (选课)一本C++原著,——12.31寒假期间一本算法类2010---算法WM操作系统---

有关Lucene的问题(2):stemming和lemmatization-程序员宅基地

问题:我试验了一下文章中提到的 stemming 和 lemmatization 将单词缩减为词根形式,如“cars”到“car”等。这种操作称为:stemming。 将单词转变为词根形式,如“drove”到“drive”等。这种操作称为:lemmatization。 试验没有成功 代码如下:public class TestNorms { publ...

在vs2010里使用EF4.3的Code First个人使用笔记-程序员宅基地

安装EF4.3工具->程序包管理器->程序包管理器控件台(需要NuGet更新到最新)键入安装EF的命令 Install-Package EntityFramework (升级EF的命令'Update-Package EntityFramework')由实体生成/更新数据库表1.编写实体类namespace TestDb{ public class ..._vs2010使用ef

springboot定时任务常见的两种处理方式_springbootreturnt<string> execute(string arg0)-程序员宅基地

一.集成xxl-job1.xxl-job简介(摘自许雪里中文教程)XXL-JOB是一个分布式任务调度平台,其核心设计目标是开发迅速、学习简单、轻量级、易扩展。现已开放源代码并接入多家公司线上产品线,开箱即用。2.springboot项目集成2.1引入jar包<!-- xxljobcore --><dependency> <groupId>co..._springbootreturnt execute(string arg0)

web前端,jsp上传文件_前端jsp文件-程序员宅基地

JSP 可以与 HTML form 标签一起使用,来允许用户上传文件到服务器。上传的文件可以是文本文件或图像文件或任何文档。本章节我们使用 Servlet 来处理文件上传,使用到的文件有:upload.jsp : 文件上传表单。message.jsp : 上传成功后跳转页面。UploadServlet.java : 上传处理 Servlet。需要引入的 jar 文件:commons-..._前端jsp文件

随便推点

OpenLayers 3 之 地图图层(Layers) 详解_tilesourcecolor.js-程序员宅基地

如果不是专业的地图工作者,看到地图,可能觉得地图就是一张将三维世界映射到二维空间,很多信息混杂在一起表示空间信息的动态可交互图片,其实这只是表面现象。实际上地图是由一个或多个图层组成的,使用不同的图层存储不同类型的地物,比如由存储道路的图层,有展示拥堵情况的图层,通常还有一个含有基础地理信息(比如政区划分)的底图图层。在 OpenLayers 中,图层是使用 layer 对象表示..._tilesourcecolor.js

vue路由传值方式-程序员宅基地

打印this.$route显示结果:跳转路由传递参数如下this.$router.push({ name: 'Page', query/params: { key: value })<router-link :to="{name:xxx,params:{key:value}}">valueString<..._vue路由传值取值

iOS开发笔记_xcode build phases 对应的值-程序员宅基地

1,iOS中如何设置项目/文件是否支持ARC旧工程配置arc方案:1,直接在targets->build phases中修改compiler Flags,是否支持arc。添加:-fobjc-arc,就可以让旧项目支持arc。如果想让原来支持arc的不使用arc则添加-fno-objc-arc因为在build phases中可以改变是否支持arc,所以应该_xcode build phases 对应的值

C语言中的文件打开与关闭函数:fopen和fclose-程序员宅基地

在进行文件读写前需要先打开文件,有打开就会有关闭操作。ANSI C规定了标准输入输出函数库,其中用函数fopen()实现文件的打开操作,文件的关闭由函数fclose()来完成。  在C语言中的文件结构类型FILE中介绍了文件结构体类型FILE,在fopen和fclose函数中都将用到FILE类型的参数,FILE结构体类型的成员虽然很多,但是在文件的打开和关闭操作中,并不会涉及到这些成员,只要定义一...

【OpenCV】106 AKAZE特征与描述子_cv2 akaze_create-程序员宅基地

106代码实验结果解释优点所有内容均来源于贾志刚老师的知识星球——OpenCV研习社,本文为个人整理学习,已获得贾老师授权,有兴趣、有能力的可以加入贾老师的知识星球进行深入学习。..._cv2 akaze_create

推荐文章

热门文章

相关标签