检查在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;