sql >> Databasteknik >  >> RDS >> Mysql

Summera en kommaseparerad kolumn i MySQL 4 (inte 5)

För att göra den här typen av icke-triviala strängmanipulationer måste du använda lagrade procedurer, som för MySQL bara dök upp för 6 år sedan, i version 5.0.

MySQL 4 är nu mycket gammalt, den senaste versionen från gren 4.1 var 4.1.25, 2008. Det stöds inte längre. De flesta Linux-distributioner tillhandahåller det inte längre. Det är verkligen dags att uppgradera.

Här är en lösning som fungerar för MySQL 5.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 ;

Exempel:

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


  1. Installera MySQL med ansible på ubuntu

  2. Hur uppdaterar man JPA-enheter när backend-databasen ändras asynkront?

  3. Smutsiga hemligheter av CASE-uttrycket

  4. Hur CURTIME() fungerar i MariaDB