MySQL数据库——查询数据案例(3)

查询以特定字符或字符串结尾的记录

字符’$’匹配以特定字符或者字符串结尾的文本。
【例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元立即加入学习!有需要的朋友戳:


腾讯课堂测试技术学习地址

欢迎转载,但未经作者同意请保留此段声明,并在文章页面明显位置给出原文链接。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值