查詢以特定字符或字符串結尾的記錄
字符’$’
匹配以特定字符或者字符串結尾的文本。
【例70】在fruits表中,查詢f_name字段以字母’y’結尾的記錄,SQL語句如下:
SELECT * FROM fruits WHERE f_name REGEXP 'y$';
+------+------+------------+---------+
| f_id | s_id | f_name | f_price |
+------+------+------------+---------+
| b1 | 101 | blackberry | 10.20 |
| b2 | 104 | berry | 7.60 |
| c0 | 101 | cherry | 3.20 |
| m2 | 105 | xbabay | 2.60 |
+--------+--------+-------------+---------+
fruits表中有4條記錄的f_name字段值是以字母’y’結尾,返回結果有4條記錄。
【例71】在fruits表中,查詢f_name字段以字符串“rry”結尾的記錄,SQL語句如下:
SELECT * FROM fruits WHERE f_name REGEXP 'rry$';
+------+------+------------+-----------+
| f_id | s_id | f_name | f_price |
+------+------+------------+-----------+
| b1 | 101 | blackberry | 10.20 |
| b2 | 104 | berry | 7.60 |
| c0 | 101 | cherry | 3.20 |
+------+------+-------------+------------+
fruits表中有3條記錄的f_name字段值是以字符串“rry”結尾,返回結果有3條記錄。
用符號"."來替代字符串中的任意一個字符
字符’.’匹配任意一個字符。
【例72】在fruits表中,查詢f_name字段值包含字母’a’與’g’且兩個字母之間只有一個字母的記錄,SQL語句如下,
SELECT * FROM fruits WHERE f_name REGEXP 'a.g';
+------+------+--------+---------+
| f_id | s_id | f_name | f_price |
+------+------+--------+---------+
| bs1 | 102 | orange | 11.20 |
| m1 | 106 | mango | 15.60 |
+------+------+--------+---------+
查詢語句中’a.g’指定匹配字符中要有字母a和g,且兩個字母之間包含單個字符,並不限定匹配的字符的位置和所在查詢字符串的總長度,因此orange和mango都符合匹配條件。
使用"*“和”+"來匹配多個字符
星號’*’
匹配前面的字符任意多次,包括0次。加號’+’
匹配前面的字符至少一次。
【例73】在fruits表中,查詢f_name字段值以字母’b’開頭,且’b’後面出現字母’a’的記錄,SQL語句如下:
SELECT * FROM fruits WHERE f_name REGEXP '^ba*';
+------+------+------------+------------+
| f_id | s_id | f_name | f_price |
+------+------+------------+------------+
| b1 | 101 | blackberry | 10.20 |
| b2 | 104 | berry | 7.60 |
| t1 | 102 | banana | 10.30 |
+------+------+------------+--------------+
星號’*’可以匹配任意多個字符,blackberry和berry中字母b後面並沒有出現字母a,但是也滿足匹配條件。
【例74】在fruits表中,查詢f_name字段值以字母’b’開頭,且’b’後面出現字母’a’至少一次的記錄,SQL語句如下:
SELECT * FROM fruits WHERE f_name REGEXP '^ba+';
+------+------+--------+---------+
| f_id | s_id | f_name | f_price |
+------+------+--------+---------+
| t1 | 102 | banana | 10.30 |
+------+------+--------+---------+
‘a+’匹配字母’a’至少一次,只有banana滿足匹配條件。
匹配指定字符串
正則表達式可以匹配指定字符串,只要這個字符串在查詢文本中即可,如要匹配多個字符串,多個字符串之間使用分隔符’|’隔開。
【例75】在fruits表中,查詢f_name字段值包含字符串“on”的記錄,SQL語句如下:
SELECT * FROM fruits WHERE f_name REGEXP 'on';
+------+------+-----------+---------+
| f_id | s_id | f_name | f_price |
+------+------+-----------+---------+
| bs2 | 105 | melon | 8.20 |
| l2 | 104 | lemon | 6.40 |
| o2 | 103 | coconut | 9.20 |
+------+------+------------+---------+
可以看到,f_name字段的melon、lemon和coconut3個值中都包含有字符串“on”,滿足匹配條件。
【例76】在fruits表中,查詢f_name字段值包含字符串“on”或者“ap”的記錄,SQL語句如下:
SELECT * FROM fruits WHERE f_name REGEXP 'on|ap';
+------+------+----------+---------+
| f_id | s_id | f_name | f_price |
+-------+-------+-----------+---------+
| a1 | 101 | apple | 5.20 |
| a2 | 103 | apricot | 2.20 |
| bs2 | 105 | melon | 8.20 |
| l2 | 104 | lemon | 6.40 |
| o2 | 103 | coconut | 9.20 |
| t2 | 102 | grape | 5.30 |
+-------+-------+----------+----------+
【例77】在fruits表中,使用LIKE運算符查詢f_name字段值爲“on”的記錄,SQL語句如下:
SELECT * FROM fruits WHERE f_name LIKE 'on';
Empty set (0.00 sec)
f_name字段沒有值爲“on”的記錄,返回結果爲空。讀者可以體會一下兩者的區別。
匹配指定字符中的任意一個
方括號“[]”指定一個字符集合,只匹配其中任何一個字符,即爲所查找的文本。
【例78】在fruits表中,查找f_name字段中包含字母’o’或者’t’的記錄,SQL語句如下:
SELECT * FROM fruits WHERE f_name REGEXP '[ot]';
+------+------+---------+---------+
| f_id | s_id | f_name | f_price |
+------+------+---------+---------+
| a2 | 103 | apricot | 2.20 |
| bs1 | 102 | orange | 11.20 |
| bs2 | 105 | melon | 8.20 |
| l2 | 104 | lemon | 6.40 |
| m1 | 106 | mango | 15.60 |
| m3 | 105 | xxtt | 11.60 |
| o2 | 103 | coconut | 9.20 |
+------+------+---------+---------+
查詢結果可以看到,所有返回的記錄的f_name字段的值中都包含有字母o或者t,或者兩個都有。
方括號“[]”還可以指定數值集合
【例79】在fruits表,查詢s_id字段中數值中包含4、5或者6的記錄,SQL語句如下:
SELECT * FROM fruits WHERE s_id REGEXP '[456]';
+------+------+---------+----------+
| f_id | s_id | f_name | f_price |
+-------+-------+---------+---------+
| b2 | 104 | berry | 7.60 |
| bs2 | 105 | melon | 8.20 |
| l2 | 104 | lemon | 6.40 |
| m1 | 106 | mango | 15.60 |
| m2 | 105 | xbabay | 2.60 |
| m3 | 105 | xxtt | 11.60 |
+-------+-------+---------+----------+
查詢結果中,s_id字段值中有3個數字中的1個即爲匹配記錄字段。
匹配集合“[456]”也可以寫成“[4-6]”即指定集合區間。例如“[a-z]”表示集合區間爲從a~z的字母,“[0-9]”表示集合區間爲所有數字。
匹配指定字符以外的字符
“[^字符集合]”
匹配不在指定集合中的任何字符。
【例80】在fruits表中,查詢f_id字段包含字母ae和數字12以外的字符的記錄,SQL語句如下:
SELECT * FROM fruits WHERE f_id REGEXP '[^a-e1-2]';
+------+------+---------+---------+
| f_id | s_id | f_name | f_price |
+------+------+---------+---------+
| b5 | 107 | xxxx | 3.60 |
| bs1 | 102 | orange | 11.20 |
| bs2 | 105 | melon | 8.20 |
| c0 | 101 | cherry | 3.20 |
| l2 | 104 | lemon | 6.40 |
| m1 | 106 | mango | 15.60 |
| m2 | 105 | xbabay | 2.60 |
| m3 | 105 | xxtt | 11.60 |
| o2 | 103 | coconut | 9.20 |
| t1 | 102 | banana | 10.30 |
| t2 | 102 | grape | 5.30 |
| t4 | 107 | xbababa | 3.60 |
+------+------+---------+---------+
【例81】在fruits表中,查詢f_name字段值出現字母’x’至少2次的記錄,SQL語句如下:
SELECT * FROM fruits WHERE f_name REGEXP 'x{2,}';
+------+------+--------+---------+
| f_id | s_id | f_name | f_price |
+------+------+--------+---------+
| b5 | 107 | xxxx | 3.60 |
| m3 | 105 | xxtt | 11.60 |
+------+-------+--------+---------+
可以看到,f_name字段的“xxxx”包含了4個字母’x’,“xxtt”包含兩個字母’x’,均爲滿足匹配條件的記錄。
【例82】在fruits表中,查詢f_name字段值出現字符串“ba”最少1次,最多3次的記錄,SQL語句如下:
SELECT * FROM fruits WHERE f_name REGEXP 'ba{1,3}';
+------+----------+-----------+---------+
| f_id | s_id | f_name | f_price |
+------+----------+----------+------------+
| m2 | 105 | xbabay | 2.60 |
| t1 | 102 | banana | 10.30 |
| t4 | 107 | xbababa | 3.60 |
+-------+--------+------------+-----------+
可以看到,f_name字段的xbabay值中“ba”出現了2次,banana中出現了1次,xbababa中出現了3次,都滿足匹配條件的記錄。
超全面的測試IT技術課程,0元立即加入學習!有需要的朋友戳:
騰訊課堂測試技術學習地址
歡迎轉載,但未經作者同意請保留此段聲明,並在文章頁面明顯位置給出原文鏈接。