如何解决检查在mysql中出现2次的字符
我正在尝试检查o是否在字符串中出现2次,并且这样做是正确的,但是它不起作用,我的代码有错误吗?
SELECT cu.*
FROM Customers cu
WHERE LOWER(cu.FirstName) REGEXP 'o{2}'
-- 'zoom' => correct
-- 'antonio' => correct
-- 'leo jisoo' => fail
谢谢
解决方法
您编写代码检查两个连续的o
,这不是您想要的。
您可以这样写:
where
FirstName like '%o%o%'
and FirstName not like '%o%o%o%'
此字符串检查完全包含o
s。
另一种方法是:
length(replace(FirstName,'o','')) = length(FirstName) - 2
,
尝试:
SELECT cu* FROM Customers cu WHERE LENGTH(LOWER(cu.FirstName)) - LENGTH(REPLACE(LOWER(cu.FirstName),'')) = 2;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。