题目:查找具有有效电子邮件的用户
准备数据
分析数据
总结
题目:查找具有有效电子邮件的用户
一个有效的电子邮件具有前缀名称和域,其中:
- 前缀 名称是一个字符串,可以包含字母(大写或小写),数字,下划线
'_'
,点'.'
和/或破折号'-'
。前缀名称 必须 以字母开头。 - 域 为
'@leetcode.com'
。
准备数据
## 创建库
create database db;
use db;## 创建库
Create table If Not Exists Users (user_id int, name varchar(30), mail varchar(50));## 向表中插入数据
Truncate table Users;
insert into Users (user_id, name, mail) values ('1', 'Winston', 'winston@leetcode.com');
insert into Users (user_id, name, mail) values ('2', 'Jonathan', 'jonathanisgreat');
insert into Users (user_id, name, mail) values ('3', 'Annabelle', 'bella-@leetcode.com');
insert into Users (user_id, name, mail) values ('4', 'Sally', 'sally.come@leetcode.com');
insert into Users (user_id, name, mail) values ('5', 'Marwan', 'quarz#2020@leetcode.com');
insert into Users (user_id, name, mail) values ('6', 'David', 'david69@gmail.com');
insert into Users (user_id, name, mail) values ('7', 'Shapiro', '.shapo@leetcode.com');
分析数据
1.前缀名以字母开头:^[a-zA-Z]
2.前缀名包括字母(大写或小写)、数字、下划线_、句点. 和横杠 - :[a-zA-z0-9\_\.\-]*
3.以域名‘
@leetcode.com
’结尾:@leetcode\.com$
select user_id,name,mail from users
where mail regexp '^[a-zA-Z][a-zA-Z0-9_.-]*\\@leetcode\\.com$';
总结
MySQL 正则表达式用于匹配和检索符合特定模式的文本内容。
其中关键词就regexp,后边可以跟
- ^ :表示以后边的字符为开头
- [] :表示括号内任意字符
- - :表示连续
- * :表示重复前面任意字符任意次数
- \ :用来转义后边的特殊字符,以表示字符原本的样子,而不是将其作为特殊字符使用
- $ :表示以前边的字符结尾