SQLServer(SQL中的正則表達式)

字號:

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