我們已經看到了MySQL的LIKE模式匹配和...% MySQL支持的另一種類型的基於正則表達式和REGEXP操作符的模式匹配操作。如果你了解PHP或Perl,那麼它很簡單,因為這這些腳本正則表達式匹配是非常相似的。
以下是可用於隨REGEXP操作符的表的模式。
實例:
現在根據上面的表,可以裝置各種不同類型的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(表示
匹配)