Mysql количество экземпляров подстроки, затем упорядочить по - PullRequest
28 голосов
/ 25 марта 2011

У меня проблема в mySQL, которая выглядит следующим образом:

  • Подсчет экземпляров подстроки в строковом поле в базе данных mySQL
  • Порядок результатов по числувхождения этой подстроки (DESC)

Я никогда не делал ничего, кроме элементарных запросов .. Я не могу найти решение в другом месте.

Ответы [ 3 ]

76 голосов
/ 25 марта 2011
SELECT (CHAR_LENGTH(str) - CHAR_LENGTH(REPLACE(str, substr, ''))) / CHAR_LENGTH(substr) AS cnt
...
ORDER BY cnt DESC

Да, выглядит раздутым, но на самом деле другого решения не существует

4 голосов
/ 01 февраля 2012
DELIMITER //
DROP FUNCTION IF EXISTS `subStringCount`//
CREATE FUNCTION `subStringCount` (sequence VARCHAR(1000), word VARCHAR(100)) RETURNS INT(4)
DETERMINISTIC
CONTAINS SQL
BEGIN
    DECLARE counter SMALLINT UNSIGNED DEFAULT 0;
    DECLARE word_length SMALLINT UNSIGNED;

    SET word_length = CHAR_LENGTH(word);

    WHILE (INSTR(sequence,word) != 0) DO
        SET counter = counter+1;
        SET sequence = SUBSTR(sequence, INSTR(sequence,word)+word_length);
    END WHILE; 

    RETURN counter;
END //
DELIMITER ;

Который можно выполнить, вызвав:

SELECT sum(subStringCount(fieldName,'subString')) FROM  `table` WHERE 1 
0 голосов
/ 24 ноября 2014

После сохранения описанной выше процедуры это сработало, чтобы получить счетчик частоты строк в таблице ...

SELECT sum(subStringCount(fieldName,'subString')) FROM  `table` WHERE 1 
...