1. 首页
  2. mysql教程

29-二十九、MySQL REGEXP 子句正则表达式查询

前面章节中我们已经了解到 MySQL 可以通过 LIKE ...% 子句来进行模糊匹配,但这都只是简单的模糊查询,也是速度最快的模糊查询

除此之外,MySQL 同样也支持其它正则表达式的匹配

MySQL 通过使用 REGEXP 操作符来进行正则表达式匹配

如果你了解过其它语言的正则表达式,比如 PHPPerl 等,那么你会对 MySQL 的正则表达式元字符非常熟悉,因为它们都类似

MySQL REGEXP 操作符支持以下几种元子符

元字符 描述
^ 匹配输入字符串的开始位置如果设置了Multiline属性,^也匹配’\n’或’\r’之后的位置
$ 匹配输入字符串的结束位置如果设置了Multiline属性,$也匹配’\n’或’\r’之前的位置
. 匹配除"\n"之外的任何单个字符如果要匹配包括’\n’在内的任何字符,请使用象'[.\n]’的模式
[…] 字符集合。匹配所包含的任意一个字符例如,'[abc]’可以匹配"plain"中的’a’
[^…] 负值字符集合。匹配未包含的任意字符例如,'[^abc]’可以匹配"plain"中的’p’
p1 p2|p3 | 匹配p1或p2或p3例如,’z|food’匹配"z"或"food"。'(z|f)ood’则匹配"zood"或"food"
* 匹配前面的子表达式零次或多次例如,zo能匹配"z"以及"zoo"。等价于{0,}。
+ 匹配前面的子表达式一次或多次例如,’zo+’能匹配"zo"以及"zoo",但不能匹配"z"。+等价于
{n} n是一个非负整数。匹配确定的n次例如,’o{2}’不能匹配"Bob"中的’o’,但是能匹配"food"中的两个o
{n,m} m和n均为非负整数,其中n<=m。最少匹配n次且最多匹配m次

MySQL 中正则表达式用的不多,但也有那么几个时刻还是很有用处的

下面我们就拿几个伪需求来看看如何使用

说是伪需求,是因为除了全文检索,其实都可以用 LIKE 语句代替

测试数据

首先运行下面的 SQL 语句准备测试数据


DROP TABLE IF EXISTS `tbl_language`; CREATE TABLE IF NOT EXISTS `tbl_language`( `id` INT UNSIGNED AUTO_INCREMENT, `name` VARCHAR(64) NOT NULL, `url` VARCHAR(128) NOT NULL, `founded_at` DATE, PRIMARY KEY ( `id` ) )ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; INSERT INTO `tbl_language` VALUES (1,'Python','https://www.ycbbs.vip','1991-2-20'), (2,'PHP','http://www.php.net','1994-1-1'), (3,'Ruby','https://www.ruby-lang.org/','1996-12-25'), (4,'Kotlin','http://kotlinlang.org/','2016-02-17'); INSERT INTO `tbl_language` (name,url) VALUES ('Perl','http://www.perl.org/'), ('Scala','http://www.scala-lang.org/');

使用 SELECT * FROM tbl_language 显示数据如下


+----+--------+----------------------------+------------+ | id | name | url | founded_at | +----+--------+----------------------------+------------+ | 1 | Python | https://www.ycbbs.vip | 1991-02-20 | | 2 | PHP | http://www.php.net | 1994-01-01 | | 3 | Ruby | https://www.ruby-lang.org/ | 1996-12-25 | | 4 | Kotlin | http://kotlinlang.org/ | 2016-02-17 | | 5 | Perl | http://www.perl.org/ | NULL | | 6 | Scala | http://www.scala-lang.org/ | NULL | +----+--------+----------------------------+------------+

范例

1、 查找 name 字段中以 Py 为开头的所有 name


SELECT name FROM tbl_language WHERE name REGEXP '^Py';

运行结果如下


+--------+ | name | +--------+ | Python | +--------+

2、 查找 url 字段中以 org/ 结尾的所有 name


SELECT name FROM tbl_language WHERE url REGEXP 'org/$';

运行结果如下


+--------+ | name | +--------+ | Ruby | | Kotlin | | Perl | | Scala | +--------+

3、 查找 url 字段中包含 lang 字符串的所有 name


SELECT name FROM tbl_language WHERE url REGEXP 'lang';

运行结果如下


+--------+ | name | +--------+ | Ruby | | Kotlin | | Scala | +--------+

4、 来一个复杂的,查找 url 字段中包含 -lan 且以 rg/ 结尾的所有 name


SELECT name FROM tbl_language WHERE url REGEXP '-lan.*rg/$';

运行结果如下


+-------+ | name | +-------+ | Ruby | | Scala | +-------+

希望读者能够给小编留言,也可以点击[此处扫下面二维码关注微信公众号](https://www.ycbbs.vip/?p=28 "此处扫下面二维码关注微信公众号")

看完两件小事

如果你觉得这篇文章对你挺有启发,我想请你帮我两个小忙:

  1. 关注我们的 GitHub 博客,让我们成为长期关系
  2. 把这篇文章分享给你的朋友 / 交流群,让更多的人看到,一起进步,一起成长!
  3. 关注公众号 「方志朋」,公众号后台回复「666」 免费领取我精心整理的进阶资源教程
  4. JS中文网,Javascriptc中文网是中国领先的新一代开发者社区和专业的技术媒体,一个帮助开发者成长的社区,是给开发者用的 Hacker News,技术文章由为你筛选出最优质的干货,其中包括:Android、iOS、前端、后端等方面的内容。目前已经覆盖和服务了超过 300 万开发者,你每天都可以在这里找到技术世界的头条内容。

    本文著作权归作者所有,如若转载,请注明出处

    转载请注明:文章转载自「 Java极客技术学习 」https://www.javajike.com

    标题:29-二十九、MySQL REGEXP 子句正则表达式查询

    链接:https://www.javajike.com/article/1592.html

« 30-三十、MySQL 数据库事务
28-二十八、MySQL NULL 值处理»

相关推荐

QR code