oracle 正则 逗号分隔,Oracle通过正则表达式分割字符串 REGEXP_SUBSTR

本文详细介绍了Oracle中的REGEXP_SUBSTR函数,展示了如何通过正则表达式对字符串进行分割和提取,包括不同参数的使用方法和示例。学习如何在SQL查询中利用正则表达式处理数据,如区分大小写、获取特定组匹配等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

REGEXP_SUBSTR函数格式如下:

function REGEXP_SUBSTR(string, pattern, position, occurrence, modifier)

string :需要进行正则处理的字符串

pattern :进行匹配的正则表达式

position :起始位置,从第几个字符开始正则表达式匹配(默认为1)

occurrence :标识第几个匹配组,默认为1

modifier :模式(‘i’不区分大小写进行检索;’c’区分大小写进行检索。默认为’c’)

SELECT REGEXP_SUBSTR('123,,,ABC,!@#,,,', '[^,]+') FROM DUAL ;

取分割后的第一个值

结果:123

SELECT REGEXP_SUBSTR('123,,,ABC,!@#,,,', '[^,]+', 2) FROM DUAL ;

从第二个字符开始匹配,取分割后的第一个值

结果:23

SELECT REGEXP_SUBSTR('123,,,ABC,!@#,,,', '[^,]+', 1, 2) FROM DUAL ;

取分割后的第二个值

结果:ABC

SELECT REGEXP_SUBSTR('123,,,ABaC,!@#,,,', '[^a]+', 1, 2, 'i') FROM DUAL ;

不区分大小写分割后的第二个值

结果:B

SELECT REGEXP_SUBSTR('123,,,ABaC,!@#,,,', '[^a]+', 1, 2, 'c') FROM DUAL ;

区分大小写分割后的第二个值

结果:C,!@#,,,

SELECT REGEXP_SUBSTR('123,,,ABC,!@#,,,', '[^,]+', 1, LEVEL)

FROM DUAL

CONNECT BY REGEXP_SUBSTR('123,,,ABC,!@#,,,', '[^,]+', 1, LEVEL) IS NOT NULL;

取分割后的所有结果 ( level  oracle关键字,表示查询深度,用来实现层级查询)

结果:

123

ABC

!@#

Oracle分割字符串 REGEXP_SUBSTR用法

分割字符串中所有指定字符,然后成多行参数说明,参数1: 待分割字符串参数2:正则表达式参数3:起始位置,从第几个字符开始正则表达式匹配(默认为1)参数4:标识第几个匹配组,默认为1参数5:模式('i' ...

Python使用正则表达式分割字符串

re.split(pattern, string, [maxsplit], [flags]) pattern:表示模式字符串,由要匹配的正则表达式转换而来. string:表示要匹配的字符串. max ...

Oracle 正则表达式 分割字符串

inData='12345|张三|男' SELECT REGEXP_SUBSTR (inData, '[^|]+', 1,1) into 用户ID FROM DUAL;SELECT REGEXP_SU ...

python正则表达式 分割字符串

使用或 标准的正则表达式有小括号,但是python的没有 # -*- coding: utf-8 -*- import sys import re import sys reload(sys) sys ...

oracle 使用正则表达式获取字符串中包含的数字

select REGEXP_REPLACE('字符串中包含的数字123,提取后就是123', '[^0-9]', '') from dual;

lua 使用正则表达式分割字符串

function string_split(str, delimiter) if str == nil or str == '' or delimiter == nil then  return ni ...

php第五天-正则表达式,字符串的匹配与查找函数,数组切割

在php中有两套正则表达式,两者功能相似,一套是由PCRE,使用"preg_"为前缀命名的函数,一套是由POSIX拓展提供的,使用以"ereg_"命名的函数 0 ...

Oracle把逗号分割的字符串转换为可放入in的条件语句的字符数列

Oracle把逗号分割的字符串转换为可放入in的条件语句的字符数列   前台传来的字符串:'589,321' SELECT*FROM TAB_A T1 WHERE  T1.CODE  IN ( SEL ...

随机推荐

Android 利用SurfaceView进行图形绘制

SurfaceView使用介绍 SurfaceView是View的一个特殊子类,它的目的是另外提供一个线程进行绘制操作. 要使用SurfaceView进行绘制,步骤如下: 1.用SurfaceView ...

【技术贴】解决xp下Microsoft.SqlServer.Management.PSProvider.dll

解决 安装SQLserver2008时有出错信息,提示:Configuration error description: 无法获得 C:\Program Files\Microsoft SQL Ser ...

JEECMS用法总结

1.循环打印栏目: [@cms_channel_list] [#list tag_list as c]

处理div 在IE6 IE7 IE8 下不居中的问题

具体处理方式如下:1 .html 顶部加入:DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "h ...

Adapter模式进行代码重构

Adapter(适配器)模式主要是将一个类的某个接口转换成一个兼容的接口. 下面是实现一个商品检索的示例 [Bad Code] public class Product { } public clas ...

(转)Java线程:线程的同步与锁

Java线程:线程的同步与锁       一.同步问题提出   线程的同步是为了防止多个线程访问一个数据对象时,对数据造成的破坏. 例如:两个线程ThreadA.ThreadB都操作同一个对象Fo ...

MongoDB Java

MongoDB Java 环境配置 在Java程序中如果要使用MongoDB,你需要确保已经安装了Java环境及MongoDB JDBC 驱动. 你可以参考本站的Java教程来安装Java程序.现在让 ...

LAMP架构(二)

第十八次课 LAMP架构(二) 目录 一.Apache默认虚拟主机 二.Apache用户认证 三.域名跳转 四.Apache访问日志 五.访问日志不记录静态文件 六.访问日志切割 七.静态元素过期时间 ...

Mybatis关联查询之一对多和多对一XML配置详解

平时在开发过程中dao.bean和XML文件都是自动生成的,很少写XML的配置关系,今天记录一下mybatis的关联查询中的多对一和一对多的情况. 首先是有两张表(学生表Student和老师Teach ...

IDEA入门

刚开始用IDEA会有很多不习惯 项目报错: Project build error: Non-resolvable parent POM for com.ks:my-springboot1:0.0.1 ...

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值