Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Summieren einer durch Kommas getrennten Spalte in MySQL 4 (nicht 5)

Um diese Art von nicht trivialen String-Manipulationen durchzuführen, müssen Sie gespeicherte Prozeduren verwenden, die für MySQL erst vor 6 Jahren in Version 5.0 erschienen sind.

MySQL 4 ist jetzt sehr alt, die neueste Version von Zweig 4.1 war 4.1.25 im Jahr 2008. Sie wird nicht mehr unterstützt. Die meisten Linux-Distributionen bieten es nicht mehr an. Es ist wirklich Zeit für ein Upgrade.

Hier ist eine Lösung, die für MySQL 5.0+ funktioniert:

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 ;

Beispiel:

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