首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >mysql regex模式匹配(天气观测站11)

mysql regex模式匹配(天气观测站11)
EN

Stack Overflow用户
提问于 2020-11-29 19:26:09
回答 1查看 163关注 0票数 0

我正在练习这个问题[天气观测站11]当我用

代码语言:javascript
复制
select distinct city
from station
where regexp_like(city, '^[^aeiou]|[^aeiou]$');

给了我正确的答案(458个结果)

代码语言:javascript
复制
select distinct city
from station
where not regexp_like(city, '^[aeiou]|[aeiou]$');

给了我错误的答案(299个结果)。

我觉得'^[^aeiou]'NOT '^[aeiou]'都应该给我一个不以艾欧为起点的结果,但实际上却不是。这两个答案之间的逻辑区别是什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-11-29 19:46:00

它们看上去是一样的,但它们是不同的。

代码语言:javascript
复制
regexp_like(city, '^[^aeiou]|[^aeiou]$')

如果city启动以辅音(非元音)结尾,这将返回匹配。

然而:

代码语言:javascript
复制
not regexp_like(city, '^[aeiou]|[aeiou]$')

如果city没有启动,并且没有以元音结尾,则返回匹配,换句话说,如果city启动,而以辅音(非元音)结尾,则返回匹配。

注意两个表达式中的ORAND之间的不同,这将导致第一个表达式与第二个表达式中的更多匹配。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65064214

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档