首页 数据库 mysql教程 MySQL如何使用正则表达式?(代码示例)

MySQL如何使用正则表达式?(代码示例)

Jan 12, 2019 pm 01:27 PM
mysql 正则表达式

MySQL支持基于正则表达式和regexp运算符的另一种模式的匹配操作。下面本篇文章就带大家认识一下MySQL的正则表达式(Regexp),通过示例来简单介绍在MySQL中如何使用正则表达式(Regexp),希望对大家有所帮助。

MySQL如何使用正则表达式?(代码示例)

MySQL 正则表达式(Regexp)的简单介绍

1、它提供了强大而灵活的匹配模式,可以帮助我们为数据库系统实现强大的搜索实用程序。

2、regexp是执行正则表达式模式匹配时使用的运算符,rlike是同义词。

3、它还支持许多元字符,这些元字符在执行模式匹配时可以提供更大的灵活性和控制。

4、反斜杠用作转义字符。如果使用了双反斜杠,则仅在模式匹配中考虑。

5、不区分大小写。

以下是正则模式表,可以与REGEXP 操作符一起使用。【相关视频教程推荐:MySQL视频教程

模式 描述(具体匹配什么)
^ 匹配字符串的开始位置。
$ 匹配字符串的结束位置。
. 匹配除 "\n" 之外的任何单个字符。
[...] 匹配所包含的任意一个字符。
[^...] 匹配未包含的任意字符。
? 匹配它前面的零个或一个子表达式(字符串)。
* 匹配它前面的零个或多个子表达式(字符串)。
+ 匹配它前面的一个或多个子表达式(字符串)。
[abc] 匹配方括号之间列出的任何字符。
[^abc] 匹配方括号之间未列出的任何字符。
[A-Z] 匹配任何大写字母。
[a-z] 匹配任何小写字母。
[0-9] 匹配从0到9的任何数字。
[[:<:]]匹配单词的开头。
[[:>:]] 匹配单词的结尾。
[:class:] 匹配字符类,即[:alpha:]匹配字母,[:space:]匹配空格,[:punct:]匹配标点符号,[:upper:] 匹配上层字母。
p1|p2|p3 匹配任何模式,p1或 p2或p3
{n} 匹配n前面元素的子表达式
{m,n} 匹配m到前面元素的n个子表达式

使用示例:

下面通过简单的示例来介绍MySQL 正则表达式(Regexp)的使用。

1、匹配字符串的开头(^):

匹配name字段以'sa'开头的所有数据,例:Sample-sam,samarth。

SELECT name FROM student_tbl WHERE name REGEXP &#39;^sa&#39;;
登录后复制

2、匹配字符串的结尾($):

匹配name字段以'on'结尾的所有数据,例:norton,merton。

SELECT name FROM student_tbl WHERE name REGEXP &#39;on$&#39;;
登录后复制

3、匹配它前面的字符串的零或一个子表达式(?):

匹配title字段包含'com'的所有数据,例:comedy ,romantic comedy。

SELECT title FROM movies_tbl WHERE title REGEXP &#39;com?&#39;;
登录后复制

4、匹配任何模式p1或p2或p3(p1 | p2 | p3):

匹配name字段包含'be'或'ae'的所有数据,例: Abel,Baer。

SELECT name FROM student_tbl WHERE REGEXP &#39;be|ae&#39; ;
登录后复制

5、匹配方括号([abc])之间列出的任何字符:

匹配name字段包含'j'或'z'的所有数据,例:Lorentz,Rajs。

SELECT name FROM student_tbl WHERE REGEXP &#39;[jz]&#39; ;
登录后复制

6、匹配'a'到'z' 之间的任何单个小写字母([a-z])([a-z]和(.)):

匹配name字段中第一位包含“b”和“g”范围内字母,第二位包含任何字符,第三位包含字母'a'的所有字符串数据,例: Tobias,sewall。

匹配任何单个字符(.)

SELECT name FROM student_tbl WHERE REGEXP &#39;[b-g].[a]&#39; ;
登录后复制

7、匹配方括号之间未列出的任何字符([^ abc]):

匹配所有不包含'j'或'z'的名称。例: nerton,sewall。

SELECT name FROM student_tbl WHERE REGEXP &#39;[^jz]&#39; ;
登录后复制

8、匹配单词结尾位置的子字符串[[:>:]]

匹配title字段中以字符“ack”结尾的所有数据,例:Black。

SELECT title FROM movies_tbl WHERE REGEXP &#39;ack[[:>:]]&#39;;
登录后复制

9、匹配单词开头位置的子字符串[[:<:]]

匹配title字段中以字符“for”开头的所有数据,例 :Forgetting Sarah Marshal.。

SELECT title FROM movies_tbl WHERE title REGEXP &#39;[[:<:]]for&#39;;
登录后复制

10、匹配字符类[:class:]:

ie [:lower:] - 小写字符,[:digit:] - 数字字符等。

匹配title字段中仅包含字母字符的所有数据,例:stranger things, Avengers。

SELECT title FROM movies_tbl WHERE REGEXP &#39;[:alpha:]&#39; ;
登录后复制

以上就是本篇文章的全部内容,希望能对大家的学习有所帮助。更多精彩内容大家可以关注php中文网相关教程栏目!!!

以上是MySQL如何使用正则表达式?(代码示例)的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

MySQL:初学者的数据管理易用性 MySQL:初学者的数据管理易用性 Apr 09, 2025 am 12:07 AM

MySQL适合初学者使用,因为它安装简单、功能强大且易于管理数据。1.安装和配置简单,适用于多种操作系统。2.支持基本操作如创建数据库和表、插入、查询、更新和删除数据。3.提供高级功能如JOIN操作和子查询。4.可以通过索引、查询优化和分表分区来提升性能。5.支持备份、恢复和安全措施,确保数据的安全和一致性。

忘记数据库密码,能在Navicat中找回吗? 忘记数据库密码,能在Navicat中找回吗? Apr 08, 2025 pm 09:51 PM

Navicat本身不存储数据库密码,只能找回加密后的密码。解决办法:1. 检查密码管理器;2. 检查Navicat的“记住密码”功能;3. 重置数据库密码;4. 联系数据库管理员。

navicat premium怎么创建 navicat premium怎么创建 Apr 09, 2025 am 07:09 AM

使用 Navicat Premium 创建数据库:连接到数据库服务器并输入连接参数。右键单击服务器并选择“创建数据库”。输入新数据库的名称和指定字符集和排序规则。连接到新数据库并在“对象浏览器”中创建表。右键单击表并选择“插入数据”来插入数据。

Navicat for MariaDB如何查看数据库密码? Navicat for MariaDB如何查看数据库密码? Apr 08, 2025 pm 09:18 PM

Navicat for MariaDB 无法直接查看数据库密码,因为密码以加密形式存储。为确保数据库安全,有三个方法可重置密码:通过 Navicat 重置密码,设置复杂密码。查看配置文件(不推荐,风险高)。使用系统命令行工具(不推荐,需要对命令行工具精通)。

mysql:简单的概念,用于轻松学习 mysql:简单的概念,用于轻松学习 Apr 10, 2025 am 09:29 AM

MySQL是一个开源的关系型数据库管理系统。1)创建数据库和表:使用CREATEDATABASE和CREATETABLE命令。2)基本操作:INSERT、UPDATE、DELETE和SELECT。3)高级操作:JOIN、子查询和事务处理。4)调试技巧:检查语法、数据类型和权限。5)优化建议:使用索引、避免SELECT*和使用事务。

navicat如何执行sql navicat如何执行sql Apr 08, 2025 pm 11:42 PM

在 Navicat 中执行 SQL 的步骤:连接到数据库。创建 SQL 编辑器窗口。编写 SQL 查询或脚本。单击“运行”按钮执行查询或脚本。查看结果(如果执行查询的话)。

Navicat 无法连接 MySQL/MariaDB/PostgreSQL 等数据库的解决方法 Navicat 无法连接 MySQL/MariaDB/PostgreSQL 等数据库的解决方法 Apr 08, 2025 pm 11:00 PM

Navicat 无法连接数据库的常见原因及其解决方法:1. 检查服务器运行状态;2. 核对连接信息;3. 调整防火墙设置;4. 配置远程访问;5. 排除网络问题;6. 检查权限;7. 保障版本兼容性;8. 排除其他可能性。

navicat怎么新建连接mysql navicat怎么新建连接mysql Apr 09, 2025 am 07:21 AM

可在 Navicat 中通过以下步骤新建 MySQL 连接:打开应用程序并选择“新建连接”(Ctrl N)。选择“MySQL”作为连接类型。输入主机名/IP 地址、端口、用户名和密码。(可选)配置高级选项。保存连接并输入连接名称。

See all articles