sql >> データベース >  >> RDS >> Mysql

MySQL 4(5ではない)でコンマ区切りの列を合計する

    この種の重要な文字列操作を行うには、ストアドプロシージャを使用する必要があります。これは、MySQLの場合、6年前のバージョン5.0でのみ登場しました。

    MySQL 4は現在非常に古く、2008年のブランチ4.1の最新バージョンは4.1.25でした。サポートされなくなりました。ほとんどのLinuxディストリビューションはもうそれを提供していません。本当にアップグレードする時が来ました。

    MySQL5.0以降で機能するソリューションは次のとおりです。

    DELIMITER //
    CREATE FUNCTION SUM_OF_LIST(s TEXT)
      RETURNS DOUBLE
      DETERMINISTIC
      NO SQL
    BEGIN
      DECLARE res DOUBLE DEFAULT 0;
      WHILE INSTR(s, ",") > 0 DO
        SET res = res + SUBSTRING_INDEX(s, ",", 1);
        SET s = MID(s, INSTR(s, ",") + 1);
      END WHILE;
      RETURN res + s;
    END //
    DELIMITER ;
    

    例:

    mysql> SELECT SUM_OF_LIST("5,2.1") AS Result;
    +--------+
    | Result |
    +--------+
    |    7.1 |
    +--------+
    


    1. 結合を使用して選択から更新する方法

    2. Postgresqlのwhere句でAlias列を使用する

    3. MySQLの数と日ごとのグループ化

    4. TSQL:現地時間をUTCに変換する方法は? (SQL Server 2008)