在SQL当中'^[a-zA-Z]+[a-zA-Z0-9_\\.\\/\\-]*@leetcode\\.com$'什么意思
时间: 2023-08-15 16:09:19 浏览: 287
在SQL中,'^[a-zA-Z] [a-zA-Z0-9_\\.\\/\\-]*@leetcode\\.com$'是一个正则表达式,用于匹配以字母开头,后跟任意数量的字母、数字、下划线、句点、斜杠和横杠的字符串,最后以'@leetcode.com'结尾的邮箱地址。这个正则表达式可以用于筛选出符合该模式的邮箱地址。
相关问题
在SQL当中regexp '^[a-zA-Z]+[a-zA-Z0-9_\\.\\/\\-]*@leetcode\\.com$'什么意思
在SQL中,regexp '^[a-zA-Z] [a-zA-Z0-9\\.\\/\\-]*@leetcode\\.com$'是一个正则表达式,用于匹配符合特定模式的字符串。具体来说,它用于匹配以字母开头,后面可以是字母、数字、下划线、句点、斜杠和横杠的任意组合,最后以"@leetcode.com"结尾的字符串。这个正则表达式可以用于筛选出符合该模式的邮件地址。
delimiter $$ create trigger email_trig after insert on user for each row begin declare msg varchar(100); if REGEXP_LIKE(old.email, '^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$') then set msg = ''; else set msg='邮箱输入错误,请重新输入'; SIGNAL SQLSTATE 'HY000' SET MESSAGE_TEXT = msg; end if; end; $$这段代码有什么错误?
这段代码有两个问题:
1. `old.email` 是不存在的,应该使用 `new.email` 获取插入的新数据的 email。
2. `SIGNAL` 语句中的 `MESSAGE_TEXT` 应该是 `MESSAGE_TEXT` 而不是 `MESSAGE`。正确的语句应该是:
```sql
delimiter $$
create trigger email_trig after insert on user
for each row
begin
declare msg varchar(100);
if REGEXP_LIKE(new.email, '^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$') then
set msg = '';
else
set msg = '邮箱输入错误,请重新输入';
SIGNAL SQLSTATE 'HY000' SET MESSAGE_TEXT = msg;
end if;
end;
$$
```
阅读全文