Перейти к основному содержимому
Версия: 2.0.x

regexp_count

Подсчитывает количество вхождений шаблона в строку. Возвращает количество вхождений шаблона регулярного выражения в целевую строку.

Синтаксис

INT regexp_count(VARCHAR str, VARCHAR pattern)

Параметры

  • str: строка для поиска. Поддерживаемый тип данных — VARCHAR. Если входное значение равно NULL, возвращается NULL.

  • pattern: шаблон регулярного выражения для поиска. Поддерживаемый тип данных — VARCHAR. Если шаблон равен NULL, возвращается NULL.

Возвращаемое значение

Возвращает INT, представляющий количество вхождений. Возвращает 0, если совпадения не найдены или если входная строка пуста.

Примеры

подсказка

Для быстрого старта с Selena см. раздел Быстрый старт.

-- Подсчёт вхождений цифр
SELECT regexp_count('abc123def456', '[0-9]');
+---------------------------------------+
| regexp_count('abc123def456', '[0-9]') |
+---------------------------------------+
| 6 |
+---------------------------------------+
-- Подсчёт вхождений точек
SELECT regexp_count('test.com test.net test.org', '\\.');
+---------------------------------------------------+
| regexp_count('test.com test.net test.org', '\\.') |
+---------------------------------------------------+
| 3 |
+---------------------------------------------------+
-- Подсчёт вхождений последовательностей пробельных символов
SELECT regexp_count('a b c d', '\\s+');
+----------------------------------------+
| regexp_count('a b c d', '\\s+') |
+----------------------------------------+
| 3 |
+----------------------------------------+
-- Подсчёт вхождений повторяющегося шаблона
SELECT regexp_count('ababababab', 'ab');
+------------------------------------+
| regexp_count('ababababab', 'ab') |
+------------------------------------+
| 5 |
+------------------------------------+
-- Использование с NULL и пустыми значениями
SELECT
regexp_count('', '.') AS empty_str,
regexp_count(NULL, '.') AS null_str,
regexp_count('abc', NULL) AS null_pattern;
+------------+----------+--------------+
| empty_str | null_str | null_pattern |
+------------+----------+--------------+
| 0 | NULL | NULL |
+------------+----------+--------------+
-- Подсчёт вхождений Unicode/китайских символов
SELECT regexp_count('abc中文def', '[\\p{Han}]+');
+-----------------------------------------------+
| regexp_count('abc中文def', '[\\p{Han}]+') |
+-----------------------------------------------+
| 1 |
+-----------------------------------------------+

С данными таблицы

CREATE TABLE sample_text (
str VARCHAR(65533) NULL,
regex VARCHAR(65533) NULL
);

INSERT INTO sample_text VALUES
('abc123def456', '[0-9]'),
('test.com test.net test.org', '\\.'),
('a b c d', '\\s+'),
('ababababab', 'ab');

SELECT str, regex, regexp_count(str, regex) AS count
FROM sample_text
ORDER BY str;
+-----------------------------+------+-------+
| str | regex| count |
+-----------------------------+------+-------+
| a b c d | \s+ | 3 |
| abc123def456 | [0-9]| 6 |
| ababababab | ab | 5 |
| test.com test.net test.org | \. | 3 |
+-----------------------------+------+-------+

keyword

REGEXP_COUNT,REGEXP,COUNT