MySQL正则表达式匹配查询(含实例)
在数据库实战开发的过程中,我们经常会遇到一些这样那样的问题,然后要卡好半天,等问题解决了才发现原来一些细节知识点还是没有掌握好。今天golang学习网就整理分享《MySQL正则表达式匹配查询(含实例)》,聊聊mysql正则表达式、匹配,希望可以帮助到正在努力赚钱的你。
一、正则表达式介绍
在过滤的时候允许使用匹配、比较和通配符寻找数据。对于基本的过滤,这些可能就足够了。但是随着过滤条件复杂性的增加,where子句本身的复杂性也有必要增加。
这里简单介绍一下使用正则表达式匹配搜索。所有种类的程序设计语言、文本编辑器、操作系统都支持正则表达式。很多程序员都将正则表达式作为自己必备的技能。熟练使用正则表达式,可以帮助我们减少很多的麻烦。
正则表达式用正则表达式语言来建立,正则表达式语言是用来完成过滤、匹配类工作的一种特殊语言。与其他语言一样,它用于自己的特殊的语法和指令。
二、使用正则表达式
正则表达式的作用是匹配文本,将一个模式与一个文本串进行比较,根据自定义的模式,过滤出你需要的数据。MySQL的正则表达式只是正则表达式的一个子集。
测试数据
mysql> select * from regexp_test; +------+----------+ | id | name | +------+----------+ | 1 | xiaoming | | 2 | xiaohong | | 3 | xiaohua | | 4 | zhangsan | | 5 | lisi | | 6 | liwu | | 7 | liliu9 | +------+----------+ 7 rows in set (0.00 sec)
1.基本字符匹配
使用like匹配name为xiao的用户,需要借助通配符%
mysql> select * from regexp_test where name like 'xiao%'; +------+----------+ | id | name | +------+----------+ | 1 | xiaoming | | 2 | xiaohong | | 3 | xiaohua | +------+----------+ 3 rows in set (0.01 sec) mysql> explain select * from regexp_test where name like 'xiao%';
使用regexp匹配name为xiao的用户,无需借助任何通配符
regexp在列值内进行匹配,如果被匹配的文本在列值中出现,regexp将会找到他,相应的行将被返回。
regexp正则表达式匹配不区分大小写
mysql> select * from regexp_test where name regexp 'xiao'; +------+----------+ | id | name | +------+----------+ | 1 | xiaoming | | 2 | xiaohong | | 3 | xiaohua | +------+----------+ 3 rows in set (0.00 sec)
2.OR匹配
使用or匹配多个符合条件的数据
mysql> select * from regexp_test where id = 1 or id = 2; +------+----------+ | id | name | +------+----------+ | 1 | xiaoming | | 2 | xiaohong | +------+----------+ 2 rows in set (0.00 sec)
使用regexp匹配多个符合条件的数据
使用regexp的
|功能类似于在select中使用or
mysql> select * from regexp_test where id regexp '1|2'; +------+----------+ | id | name | +------+----------+ | 1 | xiaoming | | 2 | xiaohong | +------+----------+ 2 rows in set (0.00 sec)
3.模糊匹配
使用or模糊匹配
mysql> select * from regexp_test where id = 1 or id = 2 or id = 8; +------+----------+ | id | name | +------+----------+ | 1 | xiaoming | | 2 | xiaohong | +------+----------+ 2 rows in set (0.00 sec)
使用
|匹配其中符合条件的
mysql> select * from regexp_test where id regexp '1|2|8'; +------+----------+ | id | name | +------+----------+ | 1 | xiaoming | | 2 | xiaohong | +------+----------+ 2 rows in set (0.00 sec)
使用
[]匹配符合条件
mysql> select * from regexp_test where id regexp '[128]'; +------+----------+ | id | name | +------+----------+ | 1 | xiaoming | | 2 | xiaohong | +------+----------+ 2 rows in set (0.00 sec)
4.匹配范围
[123456789]即为匹配到123456789这个集合
[1-9]即为匹配到123456789这个集合
[a-z]匹配任意字母
mysql> select * from regexp_test where name regexp '[a-z]'; +------+----------+ | id | name | +------+----------+ | 1 | xiaoming | | 2 | xiaohong | | 3 | xiaohua | | 4 | zhangsan | | 5 | lisi | | 6 | liwu | | 7 | liliu9 | +------+----------+ 7 rows in set (0.00 sec) mysql> select * from regexp_test where id regexp '[0-9]'; +------+----------+ | id | name | +------+----------+ | 1 | xiaoming | | 2 | xiaohong | | 3 | xiaohua | | 4 | zhangsan | | 5 | lisi | | 6 | liwu | | 7 | liliu9 | +------+----------+ 7 rows in set (0.00 sec)
5.匹配特殊字符
.和-在正则表达式中是特殊字符,需要使用两个双引号\\转义,例如\\-表示查找-,例如\\.表示查找.
原字符 说明 \\f换页 \\n换行 \\r回车 \\t制表 \\v纵向制表 至于为什么要有两个反斜杠,MySQL要求需要两个,一个是MySQL自身需要,一个正则表达式需要
## 模拟插入一条带.的数据 mysql> insert into regexp_test values(8,'z.y'); ## 因为.匹配任意字符,所以会把所有数据都匹配到 mysql> select * from regexp_test where name regexp '.'; +------+----------+ | id | name | +------+----------+ | 1 | xiaoming | | 2 | xiaohong | | 3 | xiaohua | | 4 | zhangsan | | 5 | lisi | | 6 | liwu | | 7 | liliu9 | | 8 | z.y | +------+----------+ 8 rows in set (0.00 sec) ## 当使用两个反斜杠转义后,查询出的结果和我们的期望一致 mysql> select * from regexp_test where name regexp '\\.'; +------+------+ | id | name | +------+------+ | 8 | z.y | +------+------+ 1 row in set (0.00 sec)
6. 匹配字符类
存在找出经常使用使用数字、所有字母字符或所有数字字母字符的匹配。为方便使用,可以采取预定义的字符集,称为字符类。
| 类 | 说明 |
|---|---|
| [:alnum:] | 任意字符和数字,同[a-zA-Z0-9] |
| [:alpha:] | 任意字符,同[a-zA-Z] |
| [:blank:] | 空格和制表,同[\\t] |
| [:cntrl:] | ASCAII控制字符,ASCAII 0 到31和127 |
| [:digit:] | 任意数字,同[0-9] |
| [:graph:] | 与[:print:]相同,但不包括空格 |
| [:lower:] | 任意小写字母,同[a-z] |
| [:print:] | 任意可打印字符 |
| [:punct:] | 既不在[:alnum:]又不在[:cntrl:]中的任意字符 |
| [:space:] | 包括空格在内的任意空白字符,同[\\f\\n\\r\\t\\v] |
| [:upper:] | 任意大写字母,同[A-Z] |
| [:xdigit:] | 任意十六进制数字,同[a-fA-F0-9] |
7.匹配多个实例
目前为止使用的所有正则表达式都尝试匹配单次出现。如果存在一个匹配,该行被检索出来,如果不存在,检索不出任何行。但有时需要对匹配的数目进行更强的控制。例如,你可能需要寻找所有的数,不管数中包含多少数字,或者你可能想寻找一个单词并且能够适应一个跟随的字符,等。
| 元字符 | 说明 |
|---|---|
| * | 0个或多个匹配 |
| + | 1个或多个匹配 |
| ? | ?匹配它前面的任何字符的0次活1次出现 |
| {n} | 指定数目的匹配 |
| {n,} | 不少于指定数目的匹配 |
| {n,m} | 匹配数目的范围(m不超过255) |
例一:匹配到满足xiaoh和xiao的数据
mysql> select * from regexp_test where name regexp 'xiaoh?'; +------+----------+ | id | name | +------+----------+ | 1 | xiaoming | | 2 | xiaohong | | 3 | xiaohua | +------+----------+ 3 rows in set (0.01 sec)
例二 :仔细观察{4}和{1}匹配到数据的不同点
## 匹配4个连续小写字母
mysql> select * from regexp_test where name regexp '[a-z]{4}';
+------+----------+
| id | name |
+------+----------+
| 1 | xiaoming |
| 2 | xiaohong |
| 3 | xiaohua |
| 4 | zhangsan |
| 5 | lisi |
| 6 | liwu |
| 7 | liliu9 |
+------+----------+
7 rows in set (0.00 sec)
## 匹配1个连续小写字母
mysql> select * from regexp_test where name regexp '[a-z]{1}';
+------+----------+
| id | name |
+------+----------+
| 1 | xiaoming |
| 2 | xiaohong |
| 3 | xiaohua |
| 4 | zhangsan |
| 5 | lisi |
| 6 | liwu |
| 7 | liliu9 |
| 8 | z.y |
+------+----------+
8 rows in set (0.00 sec)
8.定位符
以上介绍中都是匹配到一个字符串中任意位置的文本。为了匹配特定位置的文本,可以参考使用定位符:
| 元字符 | 说明 |
|---|---|
| ^ | 文本开始 |
| $ | 文本结尾 |
| [[:<:> | 词的开始 |
| [[:>:]] | 词的结尾 |
notes:特别需要注意的是,当在`[]`内的时候代表的是否定该集合,当在
[]外的时候代表的是文本开始
案例一:匹配以数字结尾
mysql> select * from regexp_test where name regexp '[a-z][0-9]$'; +------+--------+ | id | name | +------+--------+ | 7 | liliu9 | +------+--------+ 1 row in set (0.01 sec)
案例二:匹配以数字开头
mysql> select * from regexp_test where name regexp '^[0-9][a-z]'; +------+-------+ | id | name | +------+-------+ | 9 | 1zbc | | 10 | 1qwr2 | +------+-------+ 2 rows in set (0.00 sec)
案例三:匹配以数字开头,以数字结尾
mysql> select * from regexp_test where name regexp '^[0-9][a-z]*[0-9]$'; +------+-------+ | id | name | +------+-------+ | 10 | 1qwr2 | +------+-------+ 1 row in set (0.00 sec)
总结
好了,本文到此结束,带大家了解了《MySQL正则表达式匹配查询(含实例)》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多数据库知识!
MySQL数据库的触发器的使用
- 上一篇
- MySQL数据库的触发器的使用
- 下一篇
- 一文搞懂什么是MySQL前缀索引
-
- 数据库 · MySQL | 1天前 |
- MySQL数值函数大全及使用技巧
- 117浏览 收藏
-
- 数据库 · MySQL | 2天前 |
- 三种登录MySQL方法详解
- 411浏览 收藏
-
- 数据库 · MySQL | 3天前 |
- MySQL数据备份方法与工具推荐
- 420浏览 收藏
-
- 数据库 · MySQL | 3天前 |
- MySQL数据备份方法与工具推荐
- 264浏览 收藏
-
- 数据库 · MySQL | 4天前 |
- MySQL索引的作用是什么?
- 266浏览 收藏
-
- 数据库 · MySQL | 5天前 |
- MySQL排序原理与实战应用
- 392浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQLwhere条件查询技巧
- 333浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL常用数据类型有哪些?怎么选更合适?
- 234浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL常用命令大全管理员必学30条
- 448浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL高效批量插入数据方法大全
- 416浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL性能优化技巧大全
- 225浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL数据备份4种方法保障安全
- 145浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 3162次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 3375次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 3403次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 4506次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 3784次使用
-
- MySQL正则表达式REGEXP使用详解
- 2023-01-07 466浏览
-
- 验证Mysql中联合索引的最左匹配原则详情
- 2022-12-28 342浏览

