MySQL 查询探索(二)使用正则查询

-查询f_name字段以字母’b’开头的记录,SQL语句如下:
SELECT * FROM fruits WHERE f_name REGEXP ‘^b’;
±-----±-----±----------------±-----------+
| f_id | s_id | f_name | f_price |
±-----±-----±----------------±------------+
| b1 | 101 | blackberry | 10.20 |
| b2 | 104 | berry | 7.60 |
| t1 | 102 | banana | 10.30 |
±-----±---------±--------------±----------+
fruits表中有3条记录的f_name字段值是以字母b开头,返回结果有3条记录。
【例7.69】在fruits表中,查询f_name字段以“be”开头的记录,SQL语句如下:
SELECT * FROM fruits WHERE f_name REGEXP ‘^be’;
±-----±-----±-------±--------+
| f_id | s_id | f_name | f_price |
±-----±-----±-------±--------+
| b2 | 104 | berry | 7.60 |
±-----±-----±-------±--------+
只有berry是以“be”开头,所以查询结果中只有1条记录。
7.8.2 查询以特定字符或字符串结尾的记录
字符’ 7.70 f r u i t s f n a m e y S Q L S E L E C T F R O M f r u i t s W H E R E f n a m e R E G E X P y ’匹配以特定字符或者字符串结尾的文本。 【例7.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条记录。
【例7.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条记录。
7.8.3 用符号".“来替代字符串中的任意一个字符
字符’.’匹配任意一个字符。
【例7.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都符合匹配条件。
7.8.4 使用”“和”+"来匹配多个字符
星号’
’匹配前面的字符任意多次,包括0次。加号’+’匹配前面的字符至少一次。
【例7.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,但是也满足匹配条件。
【例7.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满足匹配条件。
7.8.5 匹配指定字符串
正则表达式可以匹配指定字符串,只要这个字符串在查询文本中即可,如要匹配多个字符串,多个字符串之间使用分隔符’|’隔开。
【例7.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”,满足匹配条件。
【例7.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 |
±------±------±---------±---------+

【例7.77】在fruits表中,使用LIKE运算符查询f_name字段值为“on”的记录,SQL语句如下:
SELECT * FROM fruits WHERE f_name LIKE ‘on’;
Empty set (0.00 sec)
f_name字段没有值为“on”的记录,返回结果为空。读者可以体会一下两者的区别。
7.8.6 匹配指定字符中的任意一个
方括号“[]”指定一个字符集合,只匹配其中任何一个字符,即为所查找的文本。
【例7.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,或者两个都有。
方括号“[]”还可以指定数值集合
【例7.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]”表示集合区间为所有数字。
7.8.7 匹配指定字符以外的字符
“[^字符集合]”匹配不在指定集合中的任何字符。
【例7.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 |
±-----±-----±--------±--------+

【例7.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’,均为满足匹配条件的记录。
【例7.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次,都满足匹配条件的记录。

发布了48 篇原创文章 · 获赞 1 · 访问量 1225

猜你喜欢

转载自blog.csdn.net/yuhezheg/article/details/104074551