欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

oracle正則表達(dá)式多項(xiàng)匹配時(shí)相似項(xiàng)有優(yōu)先級(jí)詳解

 更新時(shí)間:2023年06月27日 16:10:24   作者:他們叫我技術(shù)總監(jiān)  
這篇文章主要給大家介紹了關(guān)于oracle正則表達(dá)式多項(xiàng)匹配時(shí)相似項(xiàng)有優(yōu)先級(jí)的相關(guān)資料,Oracle中使用正則表達(dá)式需先使用REGEXP_LIKE函數(shù)來匹配字符串,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言:

Oracle常用正則表達(dá)式函數(shù)主要以下5個(gè):

  • REGEXP_LIKE:與LIKE的功能相似;
  • REGEXP_SUBSTR :與SUBSTR的功能相似;
  • REGEXP_INSTR :與INSTR的功能相似;
  • REGEXP_REPLACE :與REPLACE的功能相似;
  • REGEXP_COUNT :與COUNT的功能相似;

常用的正則表達(dá)式匹配符有以下運(yùn)算符,本文重點(diǎn)來闡述“|”指定多個(gè)選項(xiàng),容易被忽視的問題。

 一、正則表達(dá)式用法(Regexp_Like為例)

Regexp_Like()函數(shù) 模糊匹配。

1、語法規(guī)則

regexp_like(source_string,pattern[match_parameter])

2、注釋

  • source_string:傳入的字符串,可以是常量,也可以是某個(gè)值類型為串的列;
  • pattern:要進(jìn)行匹配的字符串;
  • match_parameter:文本量,進(jìn)一步訂制搜索,取值如下:
    • ‘i’ 用于不區(qū)分大小寫的匹配。
    • ‘c’ 用于區(qū)分大小寫的匹配。
    • ‘n’ 允許將句點(diǎn)“.”作為通配符來匹配換行符。如果省略該參數(shù),句點(diǎn)將不匹配換行符。
    • ‘m’ 將源串視為多行。即將“^”和“$”分別看做源串中任意位置任意行的開始和結(jié)束,而不是看作整個(gè)源串的開始或結(jié)束。如果省略該參數(shù),源串將被看作一行來處理。

如果取值不屬于上述中的某個(gè),將會(huì)報(bào)錯(cuò)。如果指定了多個(gè)互相矛盾的值,將使用最后一個(gè)值。如’ic’會(huì)被當(dāng)做’c’處理。
省略該參數(shù)時(shí):默認(rèn)區(qū)分大小寫、句點(diǎn)不匹配換行符、源串被看作一行。

3、實(shí)例

代碼:

select   * from (
select  'ABC你好'  reg from dual 
union 
select  'a233'  reg from dual)
where regexp_like(reg,'[0-9]','c')--匹配有數(shù)字的字符串

效果:

 解析:

可以看到正則表達(dá)式,通過后面的'[0-9]'的規(guī)則來獲取我們想要的數(shù)據(jù)。

二、正則表達(dá)式優(yōu)先級(jí)的注意點(diǎn)

當(dāng)我們使用REGEXP_REPLACE將多個(gè)表達(dá)式的數(shù)據(jù)替換時(shí),這時(shí)候我們要考慮替換規(guī)則有沒有類似項(xiàng),比如REGEXP_REPLACE(reg,'-BL|-BL1')即替換掉字符串reg里面包含-BL或者-BL1的字符串,此時(shí)如果我們按這種寫法REGEXP_REPLACE(reg,'-BL|-BL1'),實(shí)際效果是只會(huì)替換掉-BL,因?yàn)閛racle會(huì)按照替換規(guī)則的順序來執(zhí)行,如果滿足了第一個(gè)條件,后面的就不會(huì)再去執(zhí)行了,這也是為了加快了程序的處理速度,但同時(shí)也會(huì)造成我們常常忽略的問題。

好的,我們來看看下面的具體案例吧。

代碼:

select reg,  REGEXP_REPLACE(reg,'-BL|-BL1')reg_replace from (
select 'A_123456D-BL1' reg  FROM dual)

效果:

解析:

因?yàn)檎齽t表達(dá)式,默認(rèn)會(huì)按順序執(zhí)行,此時(shí)正則表達(dá)式,-BL滿足規(guī)則了,就不會(huì)執(zhí)行-BL1了,因此就會(huì)得到的結(jié)果是對(duì)應(yīng)的REG字符串里面替換后還會(huì)多出了一個(gè)1。

三、解決方案

現(xiàn)實(shí)情況下,我們往往會(huì)有很多替換規(guī)則,少則幾個(gè),多則好幾百,如果我們用replace函數(shù)估計(jì)要嵌套幾百次,估計(jì)你會(huì)直搖頭吧,雖然regexp_replace可以一次性將多個(gè)規(guī)則寫在一起,但是我們還是要注意上述提到的優(yōu)先級(jí)的問題。因此我們需要將相同的部分放到最后,如上面說到的“-BL”此時(shí)就能達(dá)到我們的需求了。

擴(kuò)展:

我們來看個(gè)現(xiàn)實(shí)的案例。當(dāng)面對(duì)168個(gè)規(guī)則時(shí)我們會(huì)遇到哪些問題。

1、正則表達(dá)式過長

解決方法:嵌套多個(gè)正則表達(dá)式 ,像竹筍一樣多疊幾層即可。

2、替換規(guī)則失效

出來的數(shù)據(jù)還是有我們不想要的數(shù)據(jù),比如下面的三個(gè)批次,我們只想保存一條,如果我們替換規(guī)則不當(dāng)就會(huì)造成,這三個(gè)字符串替換后還是不相同的,無法達(dá)到我們想要的效果。

解決辦法:我們首先將所有的替換規(guī)則用EXCEL表例好,然后排好優(yōu)先級(jí),然后再去修改正則表達(dá)式。如圖所示我們將規(guī)則列好,然后用不同顏色標(biāo)示優(yōu)先級(jí)。然后再整理表達(dá)式。如下圖所示小編將最小匹配項(xiàng)的表達(dá)式放到最后面了,這樣就能達(dá)到我們想要的效果了。

四、總結(jié) 

針對(duì)復(fù)雜的數(shù)據(jù)分析,首先建議從業(yè)務(wù)角度去規(guī)范,因?yàn)殡m然技術(shù)可以處理,但是歷史數(shù)據(jù)處理成本是巨大,因此一個(gè)企業(yè)的數(shù)據(jù)底座搭建,是離不開強(qiáng)標(biāo)準(zhǔn)化的數(shù)據(jù)治理的。

到此這篇關(guān)于oracle正則表達(dá)式多項(xiàng)匹配時(shí)相似項(xiàng)有優(yōu)先級(jí)的文章就介紹到這了,更多相關(guān)oracle正則表達(dá)式多項(xiàng)匹配內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 如何將Oracle的一個(gè)大數(shù)據(jù)表快速遷移到 Sqlserver2008數(shù)據(jù)庫(圖文教程)

    如何將Oracle的一個(gè)大數(shù)據(jù)表快速遷移到 Sqlserver2008數(shù)據(jù)庫(圖文教程)

    這篇文章主要介紹了如何將Oracle的一個(gè)大數(shù)據(jù)表快速遷移到 Sqlserver2008數(shù)據(jù)庫(圖文教程),本文圖文并茂給大家介紹的非常詳細(xì),需要的的朋友參考下吧
    2017-05-05
  • oracle橫向縱向求和代碼實(shí)例

    oracle橫向縱向求和代碼實(shí)例

    這篇文章主要介紹了oracle橫向縱向求和的相關(guān)內(nèi)容,涉及兩個(gè)實(shí)例,具有一定參考價(jià)值。需要的朋友可以了解。
    2017-10-10
  • Oracle進(jìn)階DECODE函數(shù)使用詳解

    Oracle進(jìn)階DECODE函數(shù)使用詳解

    這篇文章介紹了Oracle進(jìn)階DECODE函數(shù)的使用方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-12-12
  • Oracle批量查詢、刪除、更新使用BULK COLLECT提高效率

    Oracle批量查詢、刪除、更新使用BULK COLLECT提高效率

    BULK COLLECT(成批聚合類型)和數(shù)組集合type類型is table of 表%rowtype index by binary_integer用法筆記。對(duì)oracle批量查詢 刪除 更新使用bulk collect提高效果的相關(guān)知識(shí)感興趣的朋友通過本文一起學(xué)習(xí)吧
    2017-04-04
  • Oracle sqlldr導(dǎo)入一個(gè)日期列實(shí)例詳解

    Oracle sqlldr導(dǎo)入一個(gè)日期列實(shí)例詳解

    這篇文章主要介紹了Oracle sqlldr導(dǎo)入一個(gè)日期列實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • Oracle查看執(zhí)行計(jì)劃的實(shí)現(xiàn)

    Oracle查看執(zhí)行計(jì)劃的實(shí)現(xiàn)

    查看Oracle 的執(zhí)行計(jì)劃的目的是為了了解 SQL 查詢或語句在數(shù)據(jù)庫中的執(zhí)行方式和性能表現(xiàn),本文主要介紹了Oracle查看執(zhí)行計(jì)劃的實(shí)現(xiàn),感興趣的可以了解一下
    2024-02-02
  • oracle數(shù)據(jù)庫慢查詢SQL實(shí)例詳解

    oracle數(shù)據(jù)庫慢查詢SQL實(shí)例詳解

    一般的業(yè)務(wù)系統(tǒng)如果遇到性能問題,絕大部分都是來自數(shù)據(jù)庫的,有的業(yè)務(wù)一個(gè)查詢執(zhí)行時(shí)間好幾秒,這就是我們說說的SQL慢查詢,這篇文章主要給大家介紹了關(guān)于oracle數(shù)據(jù)庫慢查詢SQL的相關(guān)資料,需要的朋友可以參考下
    2024-06-06
  • Oracle中decode函數(shù)應(yīng)用示例詳解

    Oracle中decode函數(shù)應(yīng)用示例詳解

    Oracle?DECODE函數(shù)功能很強(qiáng),這篇文章主要給大家介紹了關(guān)于Oracle中decode函數(shù)應(yīng)用示例的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用oracle具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2024-05-05
  • Oracle生成不重復(fù)票號(hào)與LPAD,RPAD與NEXTVAL函數(shù)解析

    Oracle生成不重復(fù)票號(hào)與LPAD,RPAD與NEXTVAL函數(shù)解析

    這篇文章主要介紹了Oracle生成不重復(fù)票號(hào)與LPAD,RPAD與NEXTVAL函數(shù)解析,小編覺得還是挺不錯(cuò)的,這里分享給大家,供需要的朋友參考。
    2017-10-10
  • Oracle導(dǎo)入導(dǎo)出dmp文件具體示例

    Oracle導(dǎo)入導(dǎo)出dmp文件具體示例

    這篇文章主要給大家介紹了關(guān)于Oracle導(dǎo)入導(dǎo)出dmp文件的相關(guān)資料,dmp文件為oracle數(shù)據(jù)庫的數(shù)據(jù)備份文件,執(zhí)行oracle數(shù)據(jù)庫導(dǎo)出dmp文件,相當(dāng)于執(zhí)行數(shù)據(jù)庫備份;執(zhí)行導(dǎo)入dmp文件,相當(dāng)于數(shù)據(jù)庫還原,需要的朋友可以參考下
    2023-11-11

最新評(píng)論