mysql中case when嵌套regexp
时间: 2023-11-16 19:55:50 浏览: 149
可以使用以下语法:
```
SELECT column_name,
CASE
WHEN column_name REGEXP 'pattern1' THEN 'match1'
WHEN column_name REGEXP 'pattern2' THEN 'match2'
ELSE 'nomatch'
END
FROM table_name;
```
其中,`column_name` 是要匹配的列名,`pattern1` 和 `pattern2` 是正则表达式模式,`match1` 和 `match2` 是对应的匹配结果,`nomatch` 是当没有匹配时的默认结果。
例如,假设有一个表 `users`,其中有一个名为 `email` 的列,我们想要根据不同的邮箱后缀来分类。可以使用以下查询语句:
```
SELECT email,
CASE
WHEN email REGEXP '@gmail\\.com$' THEN 'Gmail'
WHEN email REGEXP '@yahoo\\.com$' THEN 'Yahoo'
ELSE 'Other'
END AS email_provider
FROM users;
```
这将返回一个包含 `email` 和 `email_provider` 两列的结果集,其中 `email_provider` 列根据邮箱后缀分类。
相关问题
MySQL regexp
好的,我明白了。针对你的问题,MySQL中的regexp用于正则表达式匹配查询。可以使用REGEXP或RLIKE关键字来进行查询。例如,使用以下查询语句可以匹配以字母'a'开头的所有单词:
SELECT * FROM table_name WHERE column_name REGEXP '^a';
mysql中为什么无法使用REGEXP_LIKE函数
根据提供的引用内容,MySQL中无法直接使用REGEXP_LIKE函数。这是因为REGEXP_LIKE函数是Oracle SQL中的函数,而不是MySQL中的函数。在MySQL中,可以使用REGEXP函数来进行正则表达式匹配。下面是一个使用REGEXP函数的示例:
```sql
SELECT column_name
FROM table_name
WHERE column_name REGEXP 'pattern';
```
在上面的示例中,column_name是要匹配的列名,table_name是要查询的表名,pattern是要匹配的正则表达式模式。
阅读全文