Количество определенных символов в MySQL столбце

Практика



Для посчета количества символов в строке (просто количества символов) служит функция:

CHAR_LENGTH(str)

например:

SELECT CHAR_LENGTH(mycol) FROM mytable;


Для подсчета количество определенных символов (например, разделителей) в строке придется написать запрос (например, чтобы посчитать количество символов ':') :

SELECT (CHAR_LENGTH(mycolumn) - CHAR_LENGTH(REPLACE(mycolumn,':',''))) div CHAR_LENGTH(':') FROM mytable;

Т.е. мы:
а) Считаем количество символов вообще
б) Заменяем нужные нам символы на пустоту
в) Считаем количество символов в строке без нужных нам к подсчету
г) Т.к. под "разделителем" может быть и многобайтовая строка - считаем длинну строки
д) Делением получаем количество вхождений разделителя в строку


Чтобы посчитать максимальное количество символов во всех строках столбца определенного вида - к выше изложенной записи добавляем впереди функцию MAX():

SELECT MAX((CHAR_LENGTH(mycolumn) - CHAR_LENGTH(REPLACE(mycolumn,':',''))) div CHAR_LENGTH(':')) FROM mytable;
создано: 2017-05-09
обновлено: 2026-03-10
4271



Помог ли вам этот ответ?
Нажмите оценку и напишите коротко почему. Так мы сможем сделать следующие ответы точнее и полезнее.
Насколько вы довольны ответом?
Ваш отзыв напрямую влияет на качество следующих подсказок и ответов.


Поделиться:
Пожаловаться

Найди готовое или заработай

С нашими удобными сервисами без комиссии*

Как это работает? | Узнать цену?

Найти исполнителя
$0 / весь год.
  • У вас есть задание, но нет времени его делать
  • Вы хотите найти профессионала для выполнения задания
  • Возможно применение функции гаранта на сделку
  • Приоритетная поддержка
  • идеально подходит для студентов, у которых нет времени для решения заданий
Готовое решение
$0 / весь год.
  • Вы можете продать (как исполнитель) или купить (как заказчик) готовое решение
  • Вам предоставят готовое решение
  • Будет предоставлено в минимальные сроки т.к. задание уже готовое
  • Вы получите базовую гарантию 8 дней
  • Вы можете заработать на материалах
  • подходит как для студентов так и для преподавателей
Я исполнитель
$0 / весь год.
  • Вы профессионал своего дела
  • У вас есть опыт и желание зарабатывать
  • Вы хотите помочь в решении задач или написании работ
  • Возможно применение функции гаранта на сделку
  • подходит для опытных студентов так и для преподавателей

Комментарии

Admin 15-07-2020
какая версия MySQL?
Admin 15-07-2020
работает
Admin 15-07-2020
(CHAR_LENGTH('mycolumn') - CHAR_LENGTH(REPLACE('mycoffflumn',':','' ))) div CHAR_LENGTH(':')
-3
Раскольникова 15-07-2020
SQL запрос: Документация
SELECT (CHAR_LENGTH(mycolumn) - CHAR_LENGTH(REPLACE(mycolumn,':',''))) div CHAR_LENGTH(':') FROM mytable;

Ответ MySQL: Документация
#1583 - Incorrect parameters in the call to native function 'CHAR_LENGTH'

Оставить комментарий

Если у вас есть какое-либо предложение, идея, благодарность или комментарий, не стесняйтесь писать. Мы очень ценим отзывы и рады услышать ваше мнение.
To reply

Лекции и учебник по "Базы данных - MySql (Maria DB)"

Термины: Базы данных - MySql (Maria DB)