亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

Oracle 正則表達式實例詳解

2020-07-26 14:07:04
字體:
來源:轉載
供稿:網友

Oracle 正則表達式實例詳解

FORM開發中的按行拆分需求:拆分后的行要有規律,并按前后層次排序

  需求分析如下:

     現有行: 2  ,      2.1  ,     2.2   ,   2.3           3
                     2.1.1,    2.1.2  ,    2.1.3 ,    2.2.1  , 2.1.1.1, 2.1.1.2,

對 2 進行拆分得到的 結果應該是 2.4 (2.4 是通過 查看歷史記錄中以2 開頭,有一位小數點,小數點后一位最大值,獲得該最大值+1 ,得到既是新行的后綴,保證拆分是按照前后順序遞增的)

對 2.1 進行拆分得到的應該是 :2.1.4 首先要保證 每次拆分得到的下一行都是多一位小數點 

對2.1 拆分 獲取最大后綴 比較對象 時候  應該匹配前綴是2.1的 且只有兩位小數點的   (排除前綴符合位數不符合的情況:2.1.1.1 ,2.1.1.2 )

對3 進行拆分 沒有歷史記錄是以 3開頭的情況 這時候 就要重新 開始拆分:得到的應該是 3.1

這里的關鍵就是匹配歷史記錄進行比較,決定拆分后的最后一位的最大值

  匹配的時候不能按照 數字的位數來判斷,因為數字有可能是兩位數,三位數,應該根據小數點來判斷

匹配要使用到 正則表達式:

與PHP、Python一樣Oracle 的正則表達式函數也是 主要由四個函數實現:相似匹配,定位查找,獲取匹配子字符串,替換匹配結果(最重要)

(1)相似匹配: regexp_like() 

regexp(source_str,pattern,match_parameter)

 第一個參數:原字符串,第二個參數匹配模式,第三個參數匹配選項

第三個參數 匹配選項在這幾個函數中都要相似作用(可選)

     常用: i:大小寫不敏感; c:大小寫敏感;          n:點號 . 不匹配換行符號;                   
                 m:多行模式;      x:擴展模式,忽略正則表達式中的空白字符。

匹配成功返回true 失敗返回 false

我的使用:

IF REGEXP_LIKE(DEL_LINE_NUMBER, '^/d*/./d*/./d*$') THEN          --匹配只有兩個小數點的數字,字符串

  模式中的符號說明:模式需要用一對雙引號括起來
                                            ^ 標明字符串的開頭,        $ 標明字符串的結尾 
                                            /d 匹配 一個0-9 的數字      * 號  匹配前面的字符0次或更多次
                                              /. 匹配一個點號,因為點號有其他含義,所以用/作為轉義

(2)定位查找字符位置:regexp_instr( )

regexp_instr(source_string ,pattern,position,occurrence ,return_option ,match_parameter )source_string:輸入的字符串pattern:正則表達式position:標識從第幾個字符開始正則表達式匹配。(默認為1)occurrence:標識第幾個匹配組。(默認為1)return_option:0――返回第一個字符出現的位置。1:pattern下一個字符起始位置。match_parameter:匹配模式

前面兩個字段必輸:

regexp_instr() select str, regexp_instr(str,'/.' ) ind , 默認從第一個字符開始查找,查找第一個.號,也可以匹配資格符合要求的字符串,寫對匹配格式即可,不一定是單個字符 regexp_instr(str,'/.',1,2) ind , 從第1個字符開始,查找第二個.號所在的位置 regexp_instr(str,'/.',5,2) ind 從第五個字符開始,查找第二個.號的位置,注意最終查找到的字符和字符串的位置是相對于查找字符串的起始位置fromtmp where id='instr';STR    IND IND IND--------------- ----- ----- -----192.168.0.1   4  8 10
  select regexp_instr('192.168.0.1','/.',1,level) ind , -- 點號. 所在的位置 regexp_instr('192.168.0.1','/d',1,level) ind -- 每個數字的位置fromdualconnectbylevel <= 9 連續匹配目標字符串出現的第一次出現的位置,第二次出現的位置,直到第九次出現的位置 IND IND----- ----- 4  1 8  2 10  3 0  5 0  6 0  7 0  9 0 11 -- 第八個數字所在位置為 11 這里不存在第九個數字,匹配不到,返回的地址為0  0  0 -- 沒有匹配到時返回為0 ,對應第一位是從1開始,而不是0 開始

我的案例:

 V_POSITION_BIT := REGEXP_INSTR(REC_DATA.DEL_LINE_NUMBER,'/.',1,2) -1; -- 第二個小數點的位數,減一

 substr(DEL_LINE_NUMBER,1,V_POSITION_BIT) -- 獲取字符串中第二個小數點之前的子串

(3) 獲取匹配子字符串:regexp_substr()

regexp_substr(source_string ,pattern,position,occurrence  ,match_parameter)

regexp_substr()在最初目的是根據字符串中某一個字符,分割字符串形成一個數組之類的

例如: 192.168.233.23   按點號"." 分組 最終結果有四個 :192     168     233     23  

注意的是 pattern書寫的格式不僅僅要用括號括起來,還要使用中括號括起來

我的案例:

REGEXP_SUBSTR(DEL_LINE_NUMBER,'[^.]+',1,1) -- 匹配前綴相同,第一個小數點前的字符select str, regexp_substr(str,'[^,]+')  str, regexp_substr(str,'[^,]+',1,1) str, 從第一位開始匹配,獲得用逗號分隔字符串之后,第一個‘分割后的子串' regexp_substr(str,'[^,]+',1,2) str, -- occurrence 第幾個匹配組 regexp_substr(str,'[^,]+',2,1) str -- position 從第幾個字符開始匹配fromtmpwhereid='substr';STR    STR    STR    STR    STR--------------- --------------- --------------- --------------- ---------------123,234,345  123    123    234    2312,34.56:78  12    12    34.56:78      2123456789  123456789  123456789  逗號分割后不存在第二個   23456789(從第二位之后開始分割,沒有就是取整體)

(4) 替換匹配結果:regexp_replace()

select str, regexp_replace(str,'020','GZ') str, regexp_replace(str,'(/d{3})(/d{3})','</2/1>') str -- 將第一、第二捕獲組交換位置,用尖括號標識出來fromtmpwhereid='replace'; STR    STR    STR--------------- --------------- ---------------(020)12345678 (GZ)12345678 (020)<456123>78001517729C28 001517729C28 <517001>729C28

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久99九色视频在线观看| 国产精品久久久久久久久久久不卡| 欧美日韩一区二区免费在线观看| 成人黄色免费网站在线观看| 亚洲人成自拍网站| 亚洲午夜色婷婷在线| 91人人爽人人爽人人精88v| 一本色道久久综合亚洲精品小说| 欧美一级淫片丝袜脚交| 一区二区欧美久久| 91在线直播亚洲| 伊人av综合网| 亚洲午夜国产成人av电影男同| 亚洲国语精品自产拍在线观看| 国产精品18久久久久久首页狼| 欧美高清无遮挡| 亚洲护士老师的毛茸茸最新章节| 亚洲精品成人久久| 国产精品久久久久久久av电影| 91精品久久久久久久久不口人| 国产欧美日韩中文字幕| 亚洲国产日韩欧美在线图片| 日韩av在线免费| 国内免费久久久久久久久久久| 青青草原成人在线视频| 国产精品综合不卡av| 国产精品久久久久av| 日韩视频永久免费观看| 国产z一区二区三区| 色婷婷av一区二区三区久久| 国产久一一精品| 日韩精品视频在线| 国产成人精品免高潮在线观看| 亚洲电影天堂av| 国产亚洲精品久久久优势| 国产精品久久久久国产a级| 欧美激情二区三区| 亚洲精品v天堂中文字幕| 久久69精品久久久久久久电影好| 97久久超碰福利国产精品…| 亚洲一区二区中文| 国产一区二区美女视频| 91理论片午午论夜理片久久| 欧美日韩国产丝袜另类| 日韩中文字幕视频| 日韩精品一区二区视频| 久久久久久久久久国产精品| 亚洲欧美日韩一区在线| 日韩av第一页| 欧美肥婆姓交大片| 欧美日韩精品在线播放| 亚洲视频日韩精品| 亚洲国产精品久久精品怡红院| 成人羞羞国产免费| 91高清在线免费观看| 欧美精品18videosex性欧美| 成人中文字幕+乱码+中文字幕| 久久精品精品电影网| 国产精品ⅴa在线观看h| 亚洲二区在线播放视频| 国产精品成人免费电影| 精品欧美aⅴ在线网站| 久久久免费精品视频| 成人激情视频网| 国产视频在线观看一区二区| 成人激情av在线| 91久久精品国产| 国模精品视频一区二区| 欧洲精品在线视频| 色久欧美在线视频观看| 日韩在线观看免费高清完整版| 国产成人精品视| 国产欧美一区二区白浆黑人| 欧美激情国产日韩精品一区18| 97视频色精品| 日韩女优人人人人射在线视频| 91超碰caoporn97人人| 日韩成人黄色av| 欧美区在线播放| 日本亚洲欧美成人| 国产精品久久久久不卡| 超碰91人人草人人干| 亚洲免费视频一区二区| 国内精品在线一区| 亚洲第一精品夜夜躁人人躁| 国产精品亚洲网站| 久久久久久久香蕉网| 欧美精品午夜视频| 日韩av片免费在线观看| 日韩视频免费看| 欧美日韩爱爱视频| 日韩av电影在线网| 日韩欧美视频一区二区三区| 7m精品福利视频导航| 亚洲成人久久电影| 国产高清视频一区三区| 国产一区玩具在线观看| 欧美黑人xxxx| 国产成人综合久久| 欧美亚洲第一页| 中文字幕无线精品亚洲乱码一区| 日韩精品有码在线观看| 国产91精品视频在线观看| 中文字幕综合一区| 91亚洲国产精品| 黄色成人av网| 亚洲精品第一国产综合精品| 色播久久人人爽人人爽人人片视av| 久久久久北条麻妃免费看| 欧美日韩免费观看中文| 欧美日韩第一页| 8x拔播拔播x8国产精品| 日本精品免费一区二区三区| 亚洲女人初尝黑人巨大| 欧美国产视频日韩| 欧美黑人xxxⅹ高潮交| 久久久久日韩精品久久久男男| 久久人人爽亚洲精品天堂| 欧美成人网在线| 欧美亚洲激情视频| 亚洲无亚洲人成网站77777| 欧美激情视频在线| 91禁外国网站| 成人av色在线观看| 美女久久久久久久久久久| 91丨九色丨国产在线| 欧美激情免费观看| 欧美性高潮床叫视频| 久久久久国产精品一区| 国产精品91久久久| 精品国产自在精品国产浪潮| 欧美日本精品在线| 国产91露脸中文字幕在线| 日韩欧美综合在线视频| 亚洲韩国青草视频| 91福利视频网| 亚洲色图在线观看| 国产69精品99久久久久久宅男| 一本久久综合亚洲鲁鲁| 97精品国产91久久久久久| 亚洲色无码播放| 欧美激情亚洲激情| 欧美伦理91i| 国产一区二区三区在线播放免费观看| www.欧美视频| 精品精品国产国产自在线| 欧美精品在线观看91| 亚洲最新av在线网站| 国产成人精品网站| 国产在线精品成人一区二区三区| 中文字幕亚洲字幕| 国产精品精品一区二区三区午夜版| 亚洲free性xxxx护士hd| 日韩视频亚洲视频| 国产性色av一区二区| 欧洲中文字幕国产精品| 久热精品视频在线观看| 欧美日本啪啪无遮挡网站| 夜夜嗨av一区二区三区四区| 日本伊人精品一区二区三区介绍| 伊人久久免费视频| 国产精品欧美一区二区| 欧美激情久久久久久| 欧美激情精品久久久久久|