데이터 베이스 MySQL 튜토리얼 Oracle正则表达式函数

Oracle正则表达式函数

Jun 07, 2016 pm 03:50 PM
oracle 기능 정기적인 표현 상어

Oracle正则表达式函数 1、正则表达式中的元字符 元字符 意思 例子 / 说明要匹配的字符是一个特殊字符、常量或者后者引用。(后引用重复上一次的匹配) /n 匹配换行符 // 匹配 / /( 匹配 ( /) 匹配 ) ^ 匹配字符串的开头位置 如果A是字符串的第一个字符,^A

Oracle正则表达式函数

1、正则表达式中的元字符

元字符

意思

例子

/

说明要匹配的字符是一个特殊字符、常量或者后者引用。(后引用重复上一次的匹配) /n 匹配换行符
// 匹配 /
/( 匹配 (
/) 匹配 )
^ 匹配字符串的开头位置 如果A是字符串的第一个字符,^A 匹配 A

$

匹配字符串的末尾位置 如果B是字符串的最后一个字符,$B 匹配 B

*

匹配前面的字符0次或多次 ba*rk可以匹配 brk、bark、baark等等
+ 匹配前面的字符1次或多次 ba+rk可以匹配 bark、baark等等,但是不能匹配brk,也就是说,最少有以一次。
? 匹配前面的字符0次或1次 ba?rk可以匹配 bark、brk等等,但是不能匹配baark。
{n} 匹配前面的字符恰好是n次,其中n是整数 hob{2}it可以匹配hobbit
{n,m} 匹配前面的字符至少是n次,最多是m次,其中n,m都是整数 hob{2,3}it可以匹配hobbit或者hobbbit
. 匹配除null以外的任意单个字符 hob.it中的.可以是任意的单个字符,如:hobsit等等
(pattern) 括号中pattern是一个子正则表达式,匹配指定pattern模式的一个子表达式。 如:aaa(x|y)可以匹配aaax或者aaay。
x|y 匹配“或” x|y可以匹配x或者y
[abc] 可以匹配abc中的任何单个字符 hello[abc]可以匹配helloa,hellob,helloc
[a-z] 可以匹配指定范围内的任何单个字符 hell[a-z]可以匹配hello或者hellz
[::] 指定一个字符类,可以匹配该类中的任何字符 [:alphanum:]可以匹配字符0-9、A-Z、a-z
[:alpha:]可以匹配字符A-Z、a-z
[:blank:]可以匹配空格或tab键
[:digit:]可以匹配数字0-9
[:graph:]可以匹配非空字符
[:lower:]可以匹配小写字母a-z
[:print:]与[:graph:]类似,不同之处在于[:print:]包括空格字符
[:punct:]可以匹配标点符号.,""等等
[:space:]可以匹配所有的空字符
[:upper:]可以匹配大写字母A-Z
[:xdigit:]可以匹配十六进制数字0-9、A-F、a-f
/n 这是对前一次匹配命中的一个后引用,其中n是一个正整数 (.)/1可以匹配两个连续相同的非空字符。(.)可以匹配除null以外的任何单个字符,而/1则重复上一次匹配的内容,即再次匹配相同的字符,因此可以匹配两个连续相同的非空字符


2、REGEXP_LIKE(x,pattern[,match_option])用于在x中查找正则表达式pattern,该函数还可以提供一个可选的参数match_option字符串说明默认的匹配选项。match_option的取值如下:
 ‘c’   说明在进行匹配时区分大小写(缺省值);
  'i'   说明在进行匹配时不区分大小写;
  'n'   允许使用可以匹配任意字符的操作符;
  'm'   将x作为一个包含多行的字符串。

sql 代码

 

  1. DECLARE   
  2.     V_FIRST_NAME VARCHAR2(50);  
  3.     V_DOB DATE ;  
  4. BEGIN   
  5.     --返回1965-1968你出生的FIRST_NAME以‘J’开头的消费者    
  6.     SELECT  FIRST_NAME,DOB  INTO  V_FIRST_NAME,V_DOB  
  7.     FROM  CUSTOMERS  
  8.     WHERE  REGEXP_LIKE(TO_CHAR(DOB,'YYYY'),'^196[5-8]$')  AND  REGEXP_LIKE(FIRST_NAME,'^J');  
  9.       
  10.     DBMS_OUTPUT.PUT_LINE(V_FIRST_NAME);  
  11.       
  12. END ;  



3、REGEXP_INSTR(x,pattern[,start[,occurrence[,return_option[, match_option]]]])用于在x中查找pattern。返回pattern在x中出现的位置。匹配位置从1开始。可以参考字符串函数 INSTR(),参数相关:
    'start'   开始查找的位置;
    'occurrence'   说明应该返回第几次出现pattern的位置;
    'eturn_option'   说明应该返回什么整数。若该参数为0,则说明要返回的整数是x中的一个字符的位置;若该参数为非0的整数,则说明要返回的整数为x中出现在pattern之后的字符的位置;
    'match_option'   修改默认的匹配设置。

sql 代码

 

  1. DECLARE   
  2.     V_RESULT INTEGER ;  
  3. BEGIN   
  4.     --返回17,找出l开头的 后跟4个任意字母的单词在第一个参数中第一次出现的位置,这里是light中l的位置    
  5.     SELECT  REGEXP_INSTR('But, soft! What light through yonder window breaks?','l[[:alpha:]] {4}',1,1,0)  INTO  V_RESULT  
  6.     FROM  DUAL;  
  7.       
  8.     DBMS_OUTPUT.PUT_LINE(V_RESULT);  
  9.       
  10.     --返回22,找出l开头的 后跟4个任意字母的单词在第一个参数中第一次出现的位置,这里是light中t的位置+1    
  11.     SELECT  REGEXP_INSTR('But, soft! What light through yonder window breaks?','l[[:alpha:]] {4}',1,1,1)  INTO  V_RESULT  
  12.     FROM  DUAL;  
  13.       
  14.     DBMS_OUTPUT.PUT_LINE(V_RESULT);  
  15. END ;  


4、REGEXP_REPLACE(x,pattern[,replace_string[,start[,occurrence[, match_option]]]])用于在x中查找pattern,并将其替换为replae_string。可以参考字符串函数 REPLACE(),参数同REGEXP_INSTR函数,参考第3

sql 代码

 

  1. DECLARE     
  2.     V_RESULT VARCHAR2(255);    
  3. BEGIN     
  4.     --返回But, soft! What XXX through yonder window breaks? 用‘XXX’代替‘light’    
  5.     SELECT  REGEXP_REPLACE('But, soft! What light through yonder window breaks?','l[[:alpha:]] {4}','XXX')  INTO  V_RESULT    
  6.     FROM  DUAL;          
  7.     DBMS_OUTPUT.PUT_LINE(V_RESULT);         
  8. END ;   


5、REGEXP_SUBSTR(x,pattern[,start[,occurrence[, match_option]]])用于在x中查找pattern并返回。可以参考字符串函数 SUBSTR(),参数同REGEXP_INSTR函数,参考第3

sql 代码

 

  1. DECLARE     
  2.     V_RESULT VARCHAR2(255);    
  3. BEGIN     
  4.     --返回‘light’    
  5.     SELECT  REGEXP_SUBSTR('But, soft! What light through yonder window breaks?','l[[:alpha:]] {4}')  INTO  V_RESULT    
  6.     FROM  DUAL;          
  7.     DBMS_OUTPUT.PUT_LINE(V_RESULT);         
  8. END ;    
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

오라클에서 두 날짜 사이의 일수를 계산하는 함수 오라클에서 두 날짜 사이의 일수를 계산하는 함수 May 08, 2024 pm 07:45 PM

오라클에서 두 날짜 사이의 일수를 계산하는 함수

Oracle 데이터베이스 로그는 얼마나 오래 보관됩니까? Oracle 데이터베이스 로그는 얼마나 오래 보관됩니까? May 10, 2024 am 03:27 AM

Oracle 데이터베이스 로그는 얼마나 오래 보관됩니까?

Oracle 데이터베이스 시작 단계의 순서는 다음과 같습니다. Oracle 데이터베이스 시작 단계의 순서는 다음과 같습니다. May 10, 2024 am 01:48 AM

Oracle 데이터베이스 시작 단계의 순서는 다음과 같습니다.

오라클에서 간격을 사용하는 방법 오라클에서 간격을 사용하는 방법 May 08, 2024 pm 07:54 PM

오라클에서 간격을 사용하는 방법

Oracle에서 특정 문자의 발생 횟수를 확인하는 방법 Oracle에서 특정 문자의 발생 횟수를 확인하는 방법 May 09, 2024 pm 09:33 PM

Oracle에서 특정 문자의 발생 횟수를 확인하는 방법

Oracle 데이터베이스 서버 하드웨어 구성 요구 사항 Oracle 데이터베이스 서버 하드웨어 구성 요구 사항 May 10, 2024 am 04:00 AM

Oracle 데이터베이스 서버 하드웨어 구성 요구 사항

오라클에는 얼마나 많은 메모리가 필요합니까? 오라클에는 얼마나 많은 메모리가 필요합니까? May 10, 2024 am 04:12 AM

오라클에는 얼마나 많은 메모리가 필요합니까?

오라클에서 문자열을 바꾸는 방법 오라클에서 문자열을 바꾸는 방법 May 08, 2024 pm 07:24 PM

오라클에서 문자열을 바꾸는 방법

See all articles