SQLServer(SQL中的正則表達(dá)式)

字號:

SQL的查詢語句中,有時(shí)會(huì)需要引進(jìn)正則表達(dá)式為其復(fù)雜搜索指定模式。下面給出一些Regexp在MYSQL語句中應(yīng)用(非全部):
    1) ^
    匹配字符串的開始部分。
    mysql> SELECT 'fo\nfo' REGEXP '^fo$'; -> 0mysql> SELECT 'fofo' REGEXP '^fo'; -> 1
    2) $
    匹配字符串的結(jié)束部分。
    mysql> SELECT 'fo\no' REGEXP '^fo\no$'; -> 1mysql> SELECT 'fo\no' REGEXP '^fo$'; -> 0
    3) .
    匹配任何字符(包括回車和新行)。
    mysql> SELECT 'fofo' REGEXP '^f.*$'; -> 1mysql> SELECT 'fo\r\nfo' REGEXP '^f.*$'; -> 1
    4) [:character_class:]
    在括號表達(dá)式中(使用[和]),[:character_class:]表示與術(shù)語類的所有字符匹配的字符類。標(biāo)準(zhǔn)的類名稱是:
    alnum
    文字?jǐn)?shù)字字符
    alpha
    文字字符
    blank
    空白字符
    cntrl
    控制字符
    digit
    數(shù)字字符
    graph
    圖形字符
    lower
    小寫文字字符
    print
    圖形或空格字符
    punct
    標(biāo)點(diǎn)字符
    space
    空格、制表符、新行、和回車
    upper
    大寫文字字符
    xdigit
    十六進(jìn)制數(shù)字字符
    它們代表在ctype(3)手冊頁面中定義的字符類。特定地區(qū)可能會(huì)提供其他類名。字符類不得用作范圍的端點(diǎn)。
    mysql> SELECT 'justalnums' REGEXP '[[:alnum:]]+'; -> 1
    mysql> SELECT '!!' REGEXP '[[:alnum:]]+'; -> 0
    5) [[:<:]], [[:>:]]
    這些標(biāo)記表示word邊界。它們分別與word的開始和結(jié)束匹配。word是一系列字字符,其前面和后面均沒有字字符。字字符是alnum類中的字母數(shù)字字符或下劃線(_)。
    mysql> SELECT 'a word a' REGEXP '[[:<:]]word[[:>:]]'; -> 1mysql> SELECT 'a xword a' REGEXP '[[:<:]]word[[:>:]]'; -> 0要想在正則表達(dá)式中使用特殊字符的文字實(shí)例,應(yīng)在其前面加上2個(gè)反斜杠“\”字符。MySQL解析程序負(fù)責(zé)解釋其中一個(gè),正則表達(dá)式庫負(fù)責(zé)解釋另一個(gè)。例如,要想與包含特殊字符“+”的字符串“1+2”匹配,在下面的正則表達(dá)式中,只有最后一個(gè)是正確的:
    mysql> SELECT '1+2' REGEXP '1+2'; -> 0mysql> SELECT '1+2' REGEXP '1\+2'; -> 0mysql> SELECT '1+2' REGEXP '1\\+2'; -> 1 其他的有關(guān)Regexp的語法,可直接參考下表:字符 含意
    \ 做為轉(zhuǎn)意,即通常在"\"后面的字符不按原來意義解釋,如/b/匹配字符"b",當(dāng)b前面加了反斜桿后/\b/,轉(zhuǎn)意為匹配一個(gè)單詞的邊界。
    -或-
    對正則表達(dá)式功能字符的還原,如"*"匹配它前面元字符0次或多次,/a*/將匹配a,aa,aaa,加了"\"后,/a\*/將只匹配"a*"。
    ^ 匹配一個(gè)輸入或一行的開頭,/^a/匹配"an A",而不匹配"An a"
    $ 匹配一個(gè)輸入或一行的結(jié)尾,/a$/匹配"An a",而不匹配"an A"
    * 匹配前面元字符0次或多次,/ba*/將匹配b,ba,baa,baaa
    + 匹配前面元字符1次或多次,/ba*/將匹配ba,baa,baaa
    ? 匹配前面元字符0次或1次,/ba*/將匹配b,ba
    (x) 匹配x保存x在名為$1...$9的變量中
    x|y 匹配x或y
    {n} 精確匹配n次
    {n,} 匹配n次以上
    {n,m} 匹配n-m次
    [xyz] 字符集(character set),匹配這個(gè)集合中的任一一個(gè)字符(或元字符)
    [^xyz] 不匹配這個(gè)集合中的任何一個(gè)字符
    [\b] 匹配一個(gè)退格符
    \b 匹配一個(gè)單詞的邊界
    \B 匹配一個(gè)單詞的非邊界
    \cX 這兒,X是一個(gè)控制符,/\cM/匹配Ctrl-M
    \d 匹配一個(gè)字?jǐn)?shù)字符,/\d/ = /[0-9]/
    \D 匹配一個(gè)非字?jǐn)?shù)字符,/\D/ = /[^0-9]/
    \n 匹配一個(gè)換行符
    \r 匹配一個(gè)回車符
    \s 匹配一個(gè)空白字符,包括\n,\r,\f,\t,\v等
    \S 匹配一個(gè)非空白字符,等于/[^\n\f\r\t\v]/
    \t 匹配一個(gè)制表符
    \v 匹配一個(gè)重直制表符
    \w 匹配一個(gè)可以組成單詞的字符(alphanumeric,這是我的意譯,含數(shù)字),包括下劃線,如[\w]匹配"$5.98"中的5,等于[a-zA-Z0-9]
    \W 匹配一個(gè)不可以組成單詞的字符,如[\W]匹配"$5.98"中的$,等于[^a-zA-Z0-9]。