web-dev-qa-db-ja.com

Mysqlは部分文字列のインスタンスをカウントし、次に並べ替えます

MySQLに次のような問題があります。

  • MySQLデータベースの文字列フィールドの部分文字列のインスタンスをカウントする
  • その部分文字列(DESC)の出現回数で結果を並べ替えます。

私は初歩的なクエリ以外に何もしたことがありません。解決策は他にありません。

29
Alan
SELECT (CHAR_LENGTH(str) - CHAR_LENGTH(REPLACE(str, substr, ''))) / CHAR_LENGTH(substr) AS cnt
...
ORDER BY cnt DESC

うん、肥大化しているように見えますが、他の可能な解決策はありません。

mysql> select (CHAR_LENGTH('asd') - CHAR_LENGTH(REPLACE('asd', 's', ''))) / CHAR_LENGTH('s');
+-----------------------------------------------------------------+
| (CHAR_LENGTH('asd') - CHAR_LENGTH(REPLACE('asd', 's', ''))) / CHAR_LENGTH('s') |
+-----------------------------------------------------------------+
|                                                          1.0000 |
+-----------------------------------------------------------------+
1 row in set (0.00 sec)



mysql> select Host, (CHAR_LENGTH(Host) - CHAR_LENGTH(REPLACE(Host, 'l', ''))) / CHAR_LENGTH('l') AS cnt from user;
+-----------+--------+
| Host      | cnt    |
+-----------+--------+
| 127.0.0.1 | 0.0000 |
| honeypot  | 0.0000 |
| honeypot  | 0.0000 |
| localhost | 2.0000 |
| localhost | 2.0000 |
+-----------+--------+
5 rows in set (0.00 sec)
77
zerkms
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 
4
FedeEDavide

上記の手順を保存した後、これはテーブル内の文字列頻度のカウントを取得するために機能しました...

SELECT sum(subStringCount(fieldName,'subString')) FROM  `table` WHERE 1 
0
Hugh Fuve