REGEXP-MySQL-正则表达式-后浪云数据库教程 (regexp函数使用方法)

教程大全 2025-07-19 07:12:13 浏览

正则表达式主要用来查询和替换符合某个模式(规则)的文本内容。例如,从一个文件中提取电话号码,查找一篇文章中重复的单词、替换文章中的敏感语汇等,这些地方都可以使用正则表达式。正则表达式强大且灵活,常用于非常复杂的查询。

MySQL 中,使用关键字指定正则表达式的字符匹配模式,其基本语法格式如下:

属性名 REGEXP ‘匹配方式’

其中,“属性名”表示需要查询的字段名称;“匹配方式”表示以哪种方式来匹配查询。“匹配方式”中有很多的模式匹配字符,它们分别表示不同的意思。下表列出了 REGEXP 操作符中常用的匹配方式。

选项 说明 例子 匹配值示例
匹配文本的开始字符 ‘^b’ 匹配以字母 b 开头的字符串 book、big、banana、bike
匹配文本的结束字符 ‘st$’ 匹配以 st 结尾的字符串 test、resist、persist
匹配任何单个字符 ‘b.t’ 匹配任何b 和 t 之间有一个字符 bit、bat、but、bite
匹配零个或多个在它前面的字符 ‘f*n’ 匹配字符 n 前面有任意个字符 f fn、fan、faan、abcn
匹配前面的字符 1 次或多次 ‘ba+’ 匹配以 b 开头,后面至少紧跟一个 a ba、bay、bare、battle
匹配包含指定字符的文本 ‘fa’ 匹配包含‘fa’的文本 fan、afa、faad
[字符集合] 匹配字符集合中的任何一个字符 ‘[xz]’ 匹配 x 或者 z dizzy、zebra、x-ray、extra
匹配不在括号中的任何字符 ‘[^abc]’ 匹配任何不包含 a、b 或 c 的字符串 desk、fox、f8ke
字符串{n,} 匹配前面的字符串至少 n 次 ‘b{2}’ 匹配 2 个或更多的 b bbb、bbbb、bbbbbbb
字符串{n,m} 匹配前面的字符串至少 n 次, 至多 m 次 ‘b{2,4}’ 匹配最少 2 个,最多 4 个 b

查询以特定字符或字符串开头的记录

字符用来匹配以特定字符或字符串开头的记录。

例 1

在 tb_students_info 表中,查询 name 字段以“J”开头的记录,SQL 语句和执行过程如下。

mysql> SELECT * FROM tb_students_info-> WHERE name REGEXP '^J';+----+------+------+------+--------+-----------+| id | name | age| sex| height | course_id |+----+------+------+------+--------+-----------+|4 | Jane |22 | 男|162 |3 ||5 | Jim|24 | 女|175 |2 ||6 | John |21 | 女|172 |4 |+----+------+------+------+--------+-----------+3 rows in set (0.01 sec)

例 2

在 tb_students_info 表中,查询 name 字段以“Ji”开头的记录,SQL 语句和执行过程如下。

mysql> SELECT * FROM tb_students_info-> WHERE name REGEXP '^Ji';+----+------+------+------+--------+-----------+| id | name | age| sex| height | course_id |+----+------+------+------+--------+-----------+|5 | Jim|24 | 女|175 |2 |+----+------+------+------+--------+-----------+1 row in set (0.00 sec)

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

字符用来匹配以特定字符或字符串结尾的记录。

例 3

在 tb_students_info 表中,查询 name 字段以“y”结尾的记录,SQL 语句和执行过程如下。

mysql> SELECT * FROM tb_students_info-> WHERE name REGEXP 'y$';+----+-------+------+------+--------+-----------+| id | name| age| sex| height | course_id |+----+-------+------+------+--------+-----------+|1 | Dany|25 | 男|160 |1 ||3 | Henry |23 | 女|185 |1 ||7 | Lily|22 | 男|165 |4 |+----+-------+------+------+--------+-----------+3 rows in set (0.00 sec)

例 4

在 tb_students_info 表中,查询 name 字段以“ry”结尾的记录,SQL 语句和执行过程如下。

mysql> SELECT * FROM tb_students_info-> WHERE name REGEXP 'ry$';+----+-------+------+------+--------+-----------+| id | name| age| sex| height | course_id |+----+-------+------+------+--------+-----------+|3 | Henry |23 | 女|185 |1 |+----+-------+------+------+--------+-----------+1 row in set (0.00 sec)

替代字符串中的任意一个字符

字符用来替代字符串中的任意一个字符。

例 5

在 tb_students_info 表中,查询 name 字段值包含“a”和“y”,且两个字母之间只有一个字母的记录,SQL 语句和执行过程如下。

mysql> SELECT * FROM tb_students_info-> WHERE name REGEXP 'a.y';+----+------+------+------+--------+-----------+| id | name | age| sex| height | course_id |+----+------+------+------+--------+-----------+|1 | Dany |25 | 男|160 |1 |+----+------+------+------+--------+-----------+1 row in set (0.00 sec)

匹配多个字符

字符和都可以匹配多个该符号之前的字符。不同的是,表示至少一个字符,而可以表示 0 个字符。

例 6

在 tb_students_info 表中,查询 name 字段值包含字母“T”,且“T”后面出现字母“h”的记录,SQL 语句和执行过程如下。

mysql> SELECT * FROM tb_students_info-> WHERE name REGEXP '^Th*';+----+--------+------+------+--------+-----------+| id | name| age| sex| height | course_id |+----+--------+------+------+--------+-----------+|9 | Thomas |22 | 女|178 |5 || 10 | Tom|23 | 女|165 |5 |+----+--------+------+------+--------+-----------+2 rows in set (0.00 sec)

例 7

在 tb_students_info 表中,查询 name 字段值包含字母“T”,且“T”后面至少出现“h”一次的记录,SQL 语句和执行过程如下。

后浪云数据库教程
mysql> SELECT * FROM tb_students_info-> WHERE name REGEXP '^Th+';+----+--------+------+------+--------+-----------+| id | name| age| sex| height | course_id |+----+--------+------+------+--------+-----------+|9 | Thomas |22 | 女|178 |5 |+----+--------+------+------+--------+-----------+1 row in set (0.00 sec)

匹配指定字符串

正则表达式可以匹配字符串。当表中的记录包含这个字符串时,就可以将该记录查询出来。指定多个字符串时,需要用隔开。只要匹配这些字符串中的任意一个即可。

例 8

在 tb_students_info 表中,查询 name 字段值包含字符串“an”的记录,SQL 语句和执行过程如下。

mysql> SELECT * FROM tb_students_info-> WHERE name REGEXP 'an';+----+-------+------+------+--------+-----------+| id | name| age| sex| height | course_id |+----+-------+------+------+--------+-----------+|1 | Dany|25 | 男|160 |1 ||4 | Jane|22 | 男|162 |3 ||8 | Susan |23 | 男|170 |5 |+----+-------+------+------+--------+-----------+3 rows in set (0.00 sec)

例 9

在 tb_students_info 表中,查询 name 字段值包含字符串“an”或“en”的记录,SQL 语句和执行过程如下。

mysql> SELECT * FROM tb_students_info-> WHERE name REGEXP 'an|en';+----+-------+------+------+--------+-----------+| id | name| age| sex| height | course_id |+----+-------+------+------+--------+-----------+|1 | Dany|25 | 男|160 |1 ||2 | Green |23 | 男|158 |2 ||3 | Henry |23 | 女|185 |1 ||4 | Jane|22 | 男|162 |3 ||8 | Susan |23 | 男|170 |5 |+----+-------+------+------+--------+-----------+5 rows in set (0.00 sec)

注意:字符串与之间不能有空格。因为,查询过程中,数据库系统会将空格也当作一个字符,这样就查询不出想要的结果。

匹配指定字符串中的任意一个

使用方括号可以将需要查询的字符组成一个字符集合。只要记录中包含方括号中的任意字符,该记录就会被查询出来。例如,通过“[abc]”可以查询包含 a、b 和 c 等 3 个字母中任意一个的记录。

例 10

在 tb_students_info 表中,查询 name 字段值包含字母“i”或“o”的记录,SQL 语句和执行过程如下。

mysql> SELECT * FROM tb_students_info-> WHERE name REGEXP '[io]';+----+--------+------+------+--------+-----------+| id | name| age| sex| height | course_id |+----+--------+------+------+--------+-----------+|5 | Jim|24 | 女|175 |2 ||6 | John|21 | 女|172 |4 ||7 | Lily|22 | 男|165 |4 ||9 | Thomas |22 | 女|178 |5 || 10 | Tom|23 | 女|165 |5 || 11 | LiMing |22 | 男|180 |7 |+----+--------+------+------+--------+-----------+6 rows in set (0.00 sec)

从查询结果可以看到,所有返回记录的 name 字段值都包含字母 i 或 o,或者两个都有。

方括号还可以指定集合的区间。例如,“[a-z]”表示从 a~z 的所有字母;“[0-9]”表示从 0~9 的所有数字;“[a-z0-9]”表示包含所有的小写字母和数字;“[a-zA-Z]”表示匹配所有字符。

例 11

在 tb_students_info 表中,查询 name 字段值中包含 1、2 或 3 的记录,SQL 语句和执行过程如下。

mysql> SELECT * FROM tb_students_info-> WHERE name REGEXP '[123]';Empty set (0.00 sec)

匹配集合“[123]”也可以写成“[1-3]”,即指定集合区间。

匹配指定字符以外的字符

[^字符集合] 用来匹配不在指定集合中的任何字符。

例 12

在 tb_students_info 表中,查询 name 字段值包含字母 a~t 以外的字符的记录,SQL 语句和执行过程如下。

mysql> SELECT * FROM tb_students_info-> WHERE name REGEXP '[^a-t]' ;+----+-------+------+------+--------+-----------+| id | name| age| sex| height | course_id |+----+-------+------+------+--------+-----------+|1 | Dany|25 | 男|160 |1 ||3 | Henry |23 | 女|185 |1 ||7 | Lily|22 | 男|165 |4 ||8 | Susan |23 | 男|170 |5 |+----+-------+------+------+--------+-----------+4 rows in set (0.00 sec)

使用{n,}或者{n,m}来指定字符串连续出现的次数

字符串{n,} 表示字符串连续出现 n 次; 字符串{n,m} 表示字符串连续出现至少 n 次,最多 m 次。

例如,a{2,} 表示字母 a 连续出现至少 2 次,也可以大于 2 次;a{2,4} 表示字母 a 连续出现最少 2 次,最多不能超过 4 次。

例 13

在 tb_students_info 表中,查询 name 字段值出现字母‘e’ 至少 2 次的记录,SQL 语句如下:

mysql> SELECT * FROM tb_students_info WHERE name REGEXP 'e{2,}';+----+-------+------+------+--------+-----------+| id | name| age| sex| height | course_id |+----+-------+------+------+--------+-----------+|2 | Green |23 | 男|158 |2 |+----+-------+------+------+--------+-----------+1 row in set (0.00 sec)

例 14

在 tb_students_info 表中,查询 name 字段值出现字符串“i” 最少 1 次,最多 3 次的记录,SQL 语句如下:

mysql> SELECT * FROM tb_students_info WHERE name REGEXP 'i{1,3}';+----+--------+------+------+--------+-----------+| id | name| age| sex| height | course_id |+----+--------+------+------+--------+-----------+|5 | Jim|24 | 女|175 |2 ||7 | Lily|22 | 男|165 |4 || 11 | LiMing |22 | 男|180 |7 |+----+--------+------+------+--------+-----------+3 rows in set (0.00 sec)

MVC后台怎么实现多个条件的模糊查询

1、%:表示任意0个或多个字符。 可匹配任意类型和长度的字符,有些情况下若是中文,请使用两个百分号(%%)表示。 SELECT * FROM [user] WHERE u_name LIKE %三%2、_: 表示任意单个字符。 匹配单个任意字符,它常用来限制表达式的字符长度语句:比如 SELECT * FROM [user] WHERE u_name LIKE _三_3、[ ]:表示括号内所列字符中的一个(类似正则表达式)。 指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。 比如 SELECT * FROM [user] WHERE u_name LIKE [张李王]三

如何在SQL Server中使用正则表达式

sqlserver中,主要有regexp_like,regexp_replace,regexp_substr,regexp_instr四个正则表达式函数。 1、regexp_like:regexp_like(x,pattern[,match_option]),查看x是否与pattern相匹配,该函数还可以提供一个可选的参数match_option字符串说明默认的匹配选项。 match_option的取值如下:c 说明在进行匹配时区分大小写(缺省值);i 说明在进行匹配时不区分大小写;n (.)点号能表示所有单个字符,包括换行(俺还不知道什么地方有用到换行.只知道sql里面可以用chr(10)表示换行、m 字符串存在换行的时候当作多行处理.这样$就可匹配每行的结尾.不然的话$只匹配字符串最后的位置、示例:select * from emp where regexp_like(ename,^a[a-z]*n$);可以查找ename中以a开头以n结尾的行.例如ename为arwen或arwin或anden.但Arwen不能被匹配.因为默认是区分大小写.如果是select * from emp where regexp_like(ename,^a[a-z]*n$,i)则可以查找ename为Arwen的行记录。 2、regexp_instr:REGEXP_INSTR(x,pattern[,start[,occurrence[,return_option[, match_option]]]])用于在x中查找pattern。 返回pattern在x中出现的位置。 匹配位置从1开始。 可以参考字符串函数 INSTR(),参数相关:start 开始查找的位置;occurrence 说明应该返回第几次出现pattern的位置;return_option 说明应该返回什么整数。 若该参数为0,则说明要返回的整数是x中的一个字符的位置;若该参数为非0的整数,则说明要返回的整数为x中出现在pattern之后 的字符的位置;match_option 修改默认的匹配设置.与regexp_like里面的相同.示例:DECLARE V_RESULT INTEGER ;BEGIN SELECTREGEXP_INSTR(hello world,o,1,1,0) INTOV_RESULTFROMDUAL; DBMS__LINE(V_RESULT); END;结果为5,即字母o第一个次出现的位置。 如果regexp_instr(hello world,o,1,1,n)其中n为除0之外的整数。 比如1,3。 则结果为6.表示第一次出现字母o的后面一个字符的位置。 如果regexp_instr(hello world,o,1,2,0)则结果为9.表示第二次出现字母o的位置.3、regexp_replace:REGEXP_REPLACE(x,pattern[,replace_string[,start[,occurrence[, match_option]]]])用于在x中查找pattern,并将其替换为replae_string。 可以参考字符串函数 REPLACE(),参数同REGEXP_INSTR函数示例:DECLARE V_RESULT varchar2(90);BEGIN SELECTREGEXP_REPLACE(hello world,o,x,1,1) INTOV_RESULTFROMDUAL;DBMS__LINE(V_RESULT); END;结果为hellx world.如果REGEXP_REPLACE(hello world,o,x),则结果为hellx wxrld.如果 REGEXP_REPLACE(hello world,o,x,1,2)则结果为hello wxrld.4、regexp_substr:REGEXP_SUBSTR(x,pattern[,start[,occurrence[, match_option]]])用于在x中查找pattern并返回。 可以参考字符串函数 SUBSTR(),参数同REGEXP_INSTR函数.例如:DECLARE V_RESULT VARCHAR2(255);BEGIN SELECTREGEXP_SUBSTR(hello world,l{2}) INTOV_RESULTFROMDUAL;DBMS__LINE(V_RESULT); END ;结果为ll查询到匹配的字符串才返回匹配的字符.没查到就返回空。

本文版权声明本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请联系本站客服,一经查实,本站将立刻删除。

发表评论

热门推荐