Oracle数据库正则表达式
正则表达式:
无论是在前端还是后台正则表达式都是一个至关重要的知识点,例如判断一个手机号码输入是否正确,如果使用Java、C或者其他语言进行字符串进行判断,也许写几十行代码都不一定能解决,而且漏洞百出,而使用正则表达式,一行代码则可轻易解决,下面是举例说明正则表达式的用法:
1: \d 代表一个(阿拉伯数字) 任意数字
例如:判断用户输入的是否为11位数字(当然手机号码是不能这么简答的表达,只是解释一下\d的用法)
select 'ok'
from dual
where regexp_like('','\d\d\d\d\d\d\d\d\d\d\d')
2: . 代表一个(任意字母) 任意字母
这里需要注意的是,如果输入的数字确实需要字母 . 的话,不能直接输 . 要转换一下格式,输入 \. 即可,这个需要注意。
3: [[:number:]] 一个任意数字(可以使十六进制)
这个用的并不多,如果现实十六进制,可以使用如下方式即可
select 'ok'
from dual
where regexp_like('str','[0-9a-fA-F]')
4: [[:alpha:]] 一个任意大小写字母
5: [ ] 匹配到方括号内的其中一个字母
方括号中只能匹配到其中的任意一个字母,或者是7 或者是8或者是9,只能是1个
select 'ok'
from dual
where regexp_like('8','[379]')
例如下面的就是ASCII码中,数字3到ASCII码 小写的 a 其中的任意一个字符的匹配
select 'ok'
from dual
where regexp_like('9','[3-a]')
当然如果是12345678这样的连续的数字可以这么写
select 'ok'
from dual
where regexp_like('str','[1-8]')
如果是要匹配 12345678 中的其中一个,或者是字母 a也行,就可以这么写,a可以写到前边,也可以写到后面,这并无所谓,因为只匹配一个而已
select 'ok'
from dual
where regexp_like('str','[a1-8]')
6: () 单词匹配
单词匹配,一般用竖线隔开,例如:小明喜欢吃苹果或者香蕉或者樱桃,此时就应该是用单词的匹配,在圆括号中任选一个。
select 'ok'
from dual
where regexp_like('小明喜欢吃苹果.','小明喜欢吃(苹果|香蕉|樱桃)\.')
7:量词:来修饰左侧的元素的数量,三个量词
  7.1: *  0到任意多个
  7.2: +  1到任意多个
  7.3: ?  0或者1个
{N},代表左侧有N个数据,比如上面的手机号码验证,\d 需要输入9个,这里就可以使用{N}来简化一下,\d是数字,然后\d{10},代表这里有10个数字
select 'ok'
from dual
where regexp_like('str','1\d{10}')
  
             如果是:{2,10} 代表左侧的东西 最少有2个,最多有10个
9:引导符: ^ :在正则表达式最前方使用 ^ ,代表只能按照表达式的格式去匹配
10:结束符: $ :在正则表达式最后面使用 ¥ ,代表只能按照表达式的格式去匹配
出现前导符的原因:因为正则表达式只匹配"表达式匹配条件的内容",之外的不匹配
11:\n 换行
Oracle数据库正则表达式的更多相关文章
- Oracle数据库基础知识
		
oracle数据库plsql developer 目录(?)[-] 一 SQL基础知识 创建删除数据库 创建删除修改表 添加修改删除列 oracle cascade用法 添加删除约束主键外 ...
 - Oracle数据库学习笔记
		
创建表的同时插入数据:create table zhang3 as select * from zhang1;create table zhang3(id,name) as select * from ...
 - oracle的正则表达式
		
阅读目录 1.oracle(regular expression)简单介绍 2.oracle正则特殊字符 3.oracle正则字符簇 4.各种操作符的运算优先级 5.模拟测试例子 6.oracle对应 ...
 - Oracle数据库常用命令(持续更新)
		
1. 查询当前用户所有的表 select * from user_tables; 2. 查询当前用户能访问的表 select * from all_tables; 3. 获取表字段 select * ...
 - Oracle数据库,忽略大小写Like模糊查询(SQL Server,MySql原理相同)
		
背景 在使用Oracle或者其它数据库时,使用like 关键字进行模糊查询是大家经常使用的功能,在纯中文环境中使用非常好用,还有一些通配符可以使用,但是在纯英文环境中,会出现大小需要精确匹配的问题,主 ...
 - Oracle数据库类型总结
		
RACLE基本数据类型(亦叫内置数据类型 built-in datatypes)可以按类型分为:字符串类型.数字类型.日期类型.LOB类型.LONG RAW& RAW类型.ROWID & ...
 - Oracle数据库基本语句练习
		
以ORACLE数据库为主提纲:第一部分.SQL语言基础 第一章:Oracle命令类别及sql简单语法介绍第二章:oracle的基本函数第三章:oracle的数据类型第四章:多表连接技术 第二部分.or ...
 - 使用Zabbix监控Oracle数据库
		
Orabbix介绍 监控Oracle数据库我们需要安装第三方提供的Zabbix插件,我们先测试比较有名的Orabbix,http://www.smartmarmot.com/product/orabb ...
 - Oracle 数据库知识汇总篇
		
Oracle 数据库知识汇总篇(更新中..) 1.安装部署篇 2.管理维护篇 3.数据迁移篇 4.故障处理篇 5.性能调优篇 6.SQL PL/SQL篇 7.考试认证篇 8.原理体系篇 9.架构设计篇 ...
 
随机推荐
- shell脚本的常用执行方式
			
1.sh+脚本的相对路径 [jinghang@hadoop101 datas]$ sh helloworld.sh helloworld sh+脚本的绝对路径 [jinghang@hadoop101 ...
 - 阿里出品的最新版 Java 开发手册,嵩山版,扫地僧
			
说起嵩山,我就想起乔峰,想起慕容复,以及他们两位老爹在少林寺大战的场景.当然了,最令我印象深刻的就是那位默默无闻,却一鸣惊人的扫地僧啊.这次,阿里出品的嵩山版 Java 开发手册的封面就有一个扫地僧, ...
 - 带你用 Python 实现自动化群控设备
			
1. 前言 群控,相信大部分人都不会陌生!印象里是一台电脑控制多台设备完成一系列的操作,更多的人喜欢把它和灰产绑定在一起! 事实上,群控在自动化测试中也被广泛使用!接下来的几篇文章,我将带大家聊聊企业 ...
 - JavaScript学习系列博客_33_JavaScript String对象
			
String对象 在底层,字符串是以数组的形式保存的.比如说一个字符串"String"以["H","t","r",&qu ...
 - JavaScript学习系列博客_23_JavaScript 构造函数
			
构造函数 - 构造函数是专门用来创建对象的函数 创建一个对象时,通过构造函数的方式来创建.这是通过Object()这个构造函数来创建的一个实例obj. var obj=new Object(); - ...
 - Magento add product attribute and assign to all group
			
$attributes = array( 'product_type' => array( 'type' => 'int', 'input' => 'select', 'source ...
 - JDK14-ZGC调研初探
			
原创声明:作者:Arnold.zhao 博客园地址:https://www.cnblogs.com/zh94 背景 公司ElasticSearch准备进行升级,而ElasticSearch7以上则是已 ...
 - 弱校验之@NotNull@NotEmpty@NotBlank
			
@NotNull 适用于非空判断 The annotated element must not be {@code null}. CharSequence, Collection, Map 和 Arr ...
 - 使用Seq搭建免费的日志服务
			
Seq简介 Seq是老外开发的一个针对.NET平台非常友好的日志服务.支持容器部署,提供一个单用户免费的开发版本. 官网:https://datalust.co/seq 使用文档:https://do ...
 - Tensorflow2(一)深度学习基础和tf.keras
			
代码和其他资料在 github 一.tf.keras概述 首先利用tf.keras实现一个简单的线性回归,如 \(f(x) = ax + b\),其中 \(x\) 代表学历,\(f(x)\) 代表收入 ...