当前位置: 首页 > news >正文

Mysql刷题之正则表达式专题

一、基本语法

要找满足正则表达式的字段:

SELECT column FROM table WHERE column REGEXP 'pattern';
-- 或
SELECT column FROM table WHERE column RLIKE 'pattern';

要找不符合正则表达式的字段:

select column from table where column not regexp 'pattern'

二、常用正则元字符​

元字符说明示例
^匹配字符串开头^abc → 以 "abc" 开头
$匹配字符串结尾xyz$ → 以 "xyz" 结尾
.匹配任意单个字符(除换行符)a.c → "abc", "a1c"
*匹配前一个字符 0 次或多次ab*c → "ac", "abbc"
+匹配前一个字符 1 次或多次ab+c → "abc", "abbc"
?匹配前一个字符 0 次或 1 次ab?c → "ac", "abc"
{n}匹配前一个字符恰好 n 次a{3} → "aaa"
{n,}匹配前一个字符至少 n 次a{2,} → "aa", "aaa"
[...]匹配括号内任意一个字符[aeiou] → 匹配任意元音字母
[^...]不匹配括号内任意字符[^0-9] → 非数字字符
``或操作符
()分组(ab)+ → "ab", "abab"

[a-z]:表示一个字符范围,匹配从 a 到 z 的任何字符。

[0-9]:表示一个字符范围,匹配从 0 到 9 的任何字符。

[a-zA-Z]:这个变量匹配从 a 到 z 或 A 到 Z 的任何字符。请注意,你可以在方括号内指定的字符范围的数量没有限制,您可以添加想要匹配的其他字符或范围。

[^a-z]:这个变量匹配不在 a 到 z 范围内的任何字符。请注意,字符 ^ 用来否定字符范围,它在方括号内的含义与它的方括号外表示开始的含义不同。

[a-z]*:表示一个字符范围,匹配从 a 到 z 的任何字符 0 次或多次。

[a-z]+:表示一个字符范围,匹配从 a 到 z 的任何字符 1 次或多次。

.:匹配任意一个字符。

\.:表示句点字符。请注意,反斜杠用于转义句点字符,因为句点字符在正则表达式中具有特殊含义。还要注意,在许多语言中,你需要转义反斜杠本身,因此需要使用\\.。

理解:

1.所谓正则表达式其实就是个字符串 , 在匹配的时候,满足这个字符串出现的规则即可。

2.请注意 ,如果要在正则表达式中匹配上面元字符本身 (比如 .),必须加转义字符 \

3.在SQL中 ,反斜杠本身也需要转义 , 也就是说 要再加一个 \  语法才正确!!

三、相关题目

1. LC 1517 查找拥有有效邮箱的用户

select user_id , name , mail
from Users
where mail regexp '^[a-zA-Z][a-zA-Z0-9_.-]*@leetcode\\.com$'

正则匹配含义如下:

^表示开头,[a-zA-Z]表示第一个字符从a-z,A-Z中随便选一个 ,

[a-zA-Z0-9_.-]* 表示a-z,A-Z,0-9这些字符随便出一个 ,并且可以出现n次或0次

@leetcode 表示前面的字符完了, 之后必须跟上@leetcode

\\. 转义字符 ,对 . 进行转义 ,表示后面必须跟一个 .

com$ 表示com完了 ,整个字符串必须以com作为结尾。

2.LC 1527 患某种疾病的患者

也可以用正则来做

相关文章:

  • MA网络笔记
  • leetcode2261. 含最多 K 个可整除元素的子数组-medium
  • 关于Python编程语言的详细介绍,结合其核心特性、应用领域和发展现状,以结构化方式呈现:
  • 网络编程 之 从BIO到 NIO加多线程高性能网络编程实战
  • JMeter 教程:响应断言
  • 融合蛋白质语言模型和图像修复模型,麻省理工与哈佛联手提出PUPS ,实现单细胞级蛋白质定位
  • recurrent neural network(rnn)
  • 记录Pycharm断点调试的一个BUG
  • Java的列表、集合、数组的添加一个元素各自用的什么方法?
  • 蜂鸣器模块
  • 7.2.顺序查找
  • 【KWDB 2025 创作者计划】_KWDB时序数据库特性及跨模查询
  • 把银河装进镜头里!动态星轨素材使用实录
  • iisARR负均衡
  • indicator-sysmonitor 在Ubuntu 右上角实时显示CPU/MEM/NET的利用率
  • 实现一个前端动态模块组件(Vite+原生JS)
  • anaconda的c++环境与ros2需要的系统变量c++环境冲突
  • 冲刺卷软考总结-案例分析
  • MySQL索引事务
  • python 标准库
  • 乐清高端网站建设/厉害的seo顾问
  • 小豹子韬韬是哪个网站做的/富阳网站seo价格
  • 公司网站制作平台/友情链接模板
  • 建设银行的英语网站首页/最新发布的最新
  • 重庆大渡口网站建设/网络营销促销方案
  • 上海嘉定区网站建设/如何获取热搜关键词