この種の重要な文字列操作を行うには、ストアドプロシージャを使用する必要があります。これは、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 |
+--------+