1. 程式人生 > >WHERE子句使用正則表示式進行搜尋過濾

WHERE子句使用正則表示式進行搜尋過濾

正則表示式:在列值內進行匹配(萬用字元匹配整列)

1基本字元匹配

SELECT prod_name
FROM products
WHERE prod_name REGEXP ‘1000’
ORDER BY prod_name;

SELECT prod_name
FROM products
WHERE prod_name REGEXP ‘.000’
ORDER BY prod_name;
.是正則表示式語言中一個特殊的字元,它表示匹配任意一個字元

使用LIKE和萬用字元表示:
SELECT prod_name
FROM products
WHERE prod_name LIKE ‘%000’
ORDER BY prod_name;

輸出:
JetPack 1000
JetPack 2000

舉例說明LIKE和REGEXP的區別:
SELECT prod_name
FROM products
WHERE prod_name LIKE ‘1000’
ORDER BY prod_name;
不返回資料

SELECT prod_name
FROM products
WHERE prod_name REGEXP ‘1000’
ORDER BY prod_name;
返回 JetPack 1000

LIKE匹配這個列,如果被匹配的文字在列值中出現,LIKE將不會找到。
REGEXP在列值中進行匹配,如果被匹配的文字在列值中出現,相應的行將被返回。REGEXP也可以使用^和$匹配整列。
匹配不區分大小寫,如果要區分大小寫,可以使用BINARY關鍵字(WHERE prod_name REGEXP BINARY ‘JetPack .000’)

2OR匹配

|位正則表示式的OR匹配,表示匹配其中之一
SELECT prod_name
FROM products
WHERE prod_name REGEXP ‘1000|2000’
ORDER BY prod_name;
輸出:
JetPack 1000
JetPack 2000

3匹配幾個字元之一

SELECT prod_name
FROM products
WHERE prod_name REGEXP ‘[123] Ton’
ORDER BY prod_name;
輸出:
1 ton anvil
2 ton anvil
SELECT prod_name
FROM products
WHERE prod_name REGEXP ‘1|2|3 Ton’
ORDER BY prod_name;
匹配1 或2 或3 ton
[^123]

匹配處這些字元以外的任何字元

4匹配範圍

[0-9] [a-z]

5匹配特殊字元

SELECT prod_name
FROM products
WHERE prod_name REGEXP ‘.’
ORDER BY prod_name;
表示匹配任意字元,每行都被檢索出來
\進行轉義
SELECT prod_name
FROM products
WHERE prod_name REGEXP ‘\.’
ORDER BY prod_name;
匹配.
空白元字元
\f 換頁
\n 換行
\r 回車
\t 製表
\v 縱向製表
\\ 反斜槓
多數正則表示式實現使用單個反斜槓轉義特殊字元,MySQL要求兩個反斜槓\(MySQL自己解釋一個,正則表示式庫解釋一個)

6匹配字元類(使用預定義的字符集)

7匹配多個例項

  • 0個或多個匹配
  • 1個或多個匹配(等於{1,})
    ? 0個或一個匹配(等於{0,1})
    {n} 指定數目的匹配
    {n,} 不少於指定數目的匹配
    {n,m} 匹配數目的範圍(m不超過255)

8定位符

^ 文字的開始
$ 文字的結尾
[[:<:]]詞的開始
[[:<:]]詞的結尾