萬盛學電腦網

 萬盛學電腦網 >> 數據庫 >> mysql教程 >> MySQL正則表達式用法詳解

MySQL正則表達式用法詳解

MySQL正則表達式使用查詢模式我們需要使用REGEXP操作符的模式匹配操作了,這個如果你學了php可能對正則不陌生了,但如果你了解pert可能會更好理解REGEXP操作符的模式匹配操作語法了,下面我來介紹一下。

我們已經看到了MySQL的LIKE模式匹配和...% MySQL支持的另一種類型的基於正則表達式和REGEXP操作符的模式匹配操作。如果你了解PHP或Perl,那麼它很簡單,因為這這些腳本正則表達式匹配是非常相似的。

以下是可用於隨REGEXP操作符的表的模式。

模式 什麼模式匹配 ^ 字符串的開始 $ 字符串的結尾 . 任何單個字符 [...] 在方括號內的任何字符列表 [^...] 非列在方括號內的任何字符 p1|p2|p3 交替匹配任何模式P1,P2或P3 * 零個或多個前面的元素 + 前面的元素的一個或多個實例 {n} 前面的元素的n個實例 {m,n} m到n個實例前面的元素

實例:

現在根據上面的表,可以裝置各種不同類型的SQL查詢以滿足要求。在這裡列出一些理解。考慮我們有一個表為person_tbl和有一個字段名為名稱:

查詢找到所有的名字以'st'開頭

mysql> SELECT name FROM person_tbl WHERE name REGEXP '^st';
查詢找到所有的名字以'ok'結尾

mysql> SELECT name FROM person_tbl WHERE name REGEXP 'ok$';
查詢找到所有的名字包函'mar'的字符串

mysql> SELECT name FROM person_tbl WHERE name REGEXP 'mar';
查詢找到所有名稱以元音開始和'ok'結束 的

mysql> SELECT name FROM person_tbl WHERE name REGEXP '^[aeiou]|ok$';


注意:

關於LIKE和REGEXP的區別:LIKE匹配整個列。如果被匹配的文本僅在列值中出現,LIKE並不會找到它,相應的行也不會返回(當然,使用通配符除外)。而REGEXP在列值內進行匹配,如果被匹配的匹配的文本在列值中出現,REGEXP將會找到它,相應的行將被返回,這時一個非常重要的差別(當然,如果適應定位符號^和$,可以實現REGEXP匹配整個列而不是列的子集)。
    關於大小寫的區分:MySQL中正則表達式匹配(從版本3.23.4後)不區分大小寫 。如果要區分大小寫,應該使用BINARY關鍵字,如where post_name REGEXP BINARY 'Hello .000'


2.關於OR匹配
    為了搜索兩個串之一,使用|, 如,select * from products where pro_id REGEXP '1000|2000'  ORDER BY pro_id;
    這樣就1000和2000都能匹配並返回,當然,使用多個|就可以匹配多個串


3.只是匹配幾個字符[]
    例如,這樣將要匹配[0123456789]可以匹配0到9,[1-4][4-9]也是合法的范圍。此外,范圍不一定只是數值的,[a-z]匹配任意字母字符
    如:SELECT prod_name FROM products WHERE prod_name REGEXP '[1-5] Ton' ORDER BY prod_name;


4.匹配特殊字符使用進行轉義
    \.能夠匹配.
    \f換頁
    \n換行
      \r回車
    \t制表
    \縱向制表


注意:為了匹配本身,需要使用\


5.匹配字符類
    [:alnum:]    任意字母和數字(通[a-zA-Z0-9])
    [:alpha:]     任意字符(同[a-zA-Z])
     [:blank:]    空格和制表符(同[\t])
     [:digit:]     任意數字(同[0-9])
     [:lower:]  任意小寫字母
     [:upper:]   任意大寫字母
     [:space:]   包括空格在內的任意空白字符


6.匹配多個實例,關於重復元字符
*      0個或者多個匹配
+     1個或者多個匹配(等於{1,})
?     1個或者多個匹配(等於{0,1})
{n}    指定數目的匹配
{n,}   不少於指定數目的匹配
{n,m}    匹配數目的范圍(m不超過255)


例子:  select prod_name from products where prod_name REGEXP '[[:DIGIT:]]{4}'   ,如前所述,[:digit:]匹配任意素子,因而它為數字的一個幾何。{4}確切的要求它前面的字符(任意數字)出現3此,所以[[:digit:]]{4}匹配連在一起的任意4位數字,當然,上面的例子也可以這樣寫REGEXP '[0-9][0-9][0-9][0-9]'


7.定位符
^  文本的開始
&  文本的結尾
[[:<:]]   詞的開始
[[:>:]]   詞的結尾
通過使用這些定位符,能夠使REGEXP起類似LIKE的作用


一般的正則表達式使用了某些特殊的結構,所以它能匹配更多的字符串。例如,正則
表達式hello|word既能匹配字符串“hello”也能匹配字符串“word”。
舉一個更復雜一點的例子,正則表達式b[an]*s可以匹配字符串“bananas”、“baaaaa
s”
、“bs”以及其他任何以b開頭以s結尾的字符串,中間可以包括任意個a和任意個n的組
合。
一個正則表達式中的可以使用以下保留字
^
所匹配的字符串以後面的字符串開頭
mysql> select "fonfo" regexp "^fo$";      -> 0(表示不匹配)
mysql> select "fofo" regexp "^fo";       -> 1(表示匹配)
$
所匹配的字符串以前面的字符串結尾
mysql> select "fono" regexp "^fono$";     -> 1(表示匹配)
mysql> select "fono" regexp "^fo$";      -> 0(表示不匹配)
.. 
匹配任何字符(包括新行)
mysql> select "fofo" regexp "^f.*";       -> 1(表示匹配)
mysql> select "fonfo" regexp "^f.*";      -> 1(表示匹配)
a*
匹配任意多個a(包括空串)
mysql> select "ban" regexp "^ba*n";       -> 1(表示匹配)
mysql> select "baaan" regexp "^ba*n";      -> 1(表示匹配)
mysql> select "bn" regexp "^ba*n";       -> 1(表示匹配)
a+
匹配任意多個a(不包括空串)
mysql> select "ban" regexp "^ba+n";       -> 1(表示匹配)
mysql> select "bn" regexp "^ba+n";       -> 0(表示不匹配)
a?
匹配一個或零個a
mysql> select "bn" regexp "^ba?n";       -> 1(表示匹配)
mysql> select "ban" regexp "^ba?n";       -> 1(表示匹配)
mysql> select "baan" regexp "^ba?n";      -> 0(表示不匹配)
de|abc
匹配de或abc
mysql> select "pi" regexp "pi|apa";       -> 1(表示匹配)
mysql> select "axe" regexp "pi|apa";      -> 0(表示不匹配)
mysql> select "apa" regexp "pi|apa";      -> 1(表示匹配)
mysql> select "apa" regexp "^(pi|apa)$";    -> 1(表示匹配)
mysql> select "pi" regexp "^(pi|apa)$";     -> 1(表示匹配)
mysql> select "pix" regexp "^(pi|apa)$";    -> 0(表示不匹配)
(abc)*
匹配任意多個abc(包括空串)
mysql> select "pi" regexp "^(pi)*$";      -> 1(表示匹配)
mysql> select "pip" regexp "^(pi)*$";      -> 0(表示不匹配)
mysql> select "pipi" regexp "^(pi)*$";     -> 1(表示匹配)
{1}
{2,3}
這是一個更全面的方法,它可以實現前面好幾種保留字的功能
a*
可以寫成a{0,}
a+
可以寫成a{1,}
a?
可以寫成a{0,1}
在{}內只有一個整型參數i,表示字符只能出現i次;在{}內有一個整型參數i,
後面跟一個“,”,表示字符可以出現i次或i次以上;在{}內只有一個整型參數i,
後面跟一個“,”,再跟一個整型參數j,表示字符只能出現i次以上,j次以下
(包括i次和j次)。其中的整型參數必須大於等於0,小於等於 re_dup_max(默認是25
5)。
如果有兩個參數,第二個必須大於等於第一個
[a-dx]
匹配“a”、“b”、“c”、“d”或“x”
[^a-dx]
匹配除“a”、“b”、“c”、“d”、“x”以外的任何字符。
“[”、“]”必須成對使用
mysql> select "axbc" regexp "[a-dxyz]";     -> 1(表示匹配)
mysql> select "axbc" regexp "^[a-dxyz]$";    -> 0(表示不匹配)
mysql> select "axbc" regexp "^[a-dxyz]+$";   -> 1(表示匹配)
mysql> select "axbc" regexp "^[^a-dxyz]+$";   -> 0(表示不匹配)
mysql> select "gheis" regexp "^[^a-dxyz]+$";  -> 1(表示匹配)
mysql> select "gheisa" regexp "^[^a-dxyz]+$";  -> 0(表示不匹配)
------------------------------------------------------------
[[.characters.]]
表示比較元素的順序。在括號內的字符順序是唯一的。但是括號中可以包含通配符,
所以他能匹配更多的字符。舉例來說:正則表達式[[.ch.]]*c匹配chchcc的前五個字符

[=character_class=]
表示相等的類,可以代替類中其他相等的元素,包括它自己。例如,如果o和(+)是
一個相等的類的成員,那麼[[=o=]]、[[=(+)=]]和[o(+)]是完全等價的。
[:character_class:]
在括號裡面,在[:和:]中間是字符類的名字,可以代表屬於這個類的所有字符。
字符類的名字有: alnum、digit、punct、alpha、graph、space、blank、lower、uppe
r、cntrl、print和xdigit
mysql> select "justalnums" regexp "[[:alnum:]]+";    -> 1(表示匹配)
mysql> select "!!" regexp "[[:alnum:]]+";        -> 0(表示不匹配)
[[:<:]]
[[:>:]]
分別匹配一個單詞開頭和結尾的空的字符串,這個單詞開頭和結尾都不是包含在alnum中
的字符也不能是下劃線。
mysql> select "a word a" regexp "[[:<:]]word[[:>:]]";   -> 1(表示匹配)
mysql> select "a xword a" regexp "[[:<:]]word[[:>:]]";   -> 0(表示不匹配)
mysql> select "weeknights" regexp "^(wee|week)(knights|nights)$"; -> 1(表示
匹配)

copyright © 萬盛學電腦網 all rights reserved