我正在练习这个问题[天气观测站11]当我用
select distinct city
from station
where regexp_like(city, '^[^aeiou]|[^aeiou]$');给了我正确的答案(458个结果)
select distinct city
from station
where not regexp_like(city, '^[aeiou]|[aeiou]$');给了我错误的答案(299个结果)。
我觉得'^[^aeiou]'和NOT '^[aeiou]'都应该给我一个不以艾欧为起点的结果,但实际上却不是。这两个答案之间的逻辑区别是什么?
发布于 2020-11-29 19:46:00
它们看上去是一样的,但它们是不同的。
regexp_like(city, '^[^aeiou]|[^aeiou]$')如果city启动或以辅音(非元音)结尾,这将返回匹配。
然而:
not regexp_like(city, '^[aeiou]|[aeiou]$')如果city没有启动,并且没有以元音结尾,则返回匹配,换句话说,如果city启动,而以辅音(非元音)结尾,则返回匹配。
注意两个表达式中的OR和AND之间的不同,这将导致第一个表达式与第二个表达式中的更多匹配。
https://stackoverflow.com/questions/65064214
复制相似问题