sql >> Database >  >> RDS >> Mysql

Een door komma's gescheiden kolom optellen in MySQL 4 (niet 5)

Om dit soort niet-triviale stringmanipulaties uit te voeren, moet je opgeslagen procedures gebruiken, die voor MySQL pas 6 jaar geleden verschenen, in versie 5.0.

MySQL 4 is nu erg oud, de laatste versie van branch 4.1 was 4.1.25, in 2008. Het wordt niet meer ondersteund. De meeste Linux-distributies bieden het niet meer. Het is echt tijd om te upgraden.

Hier is een oplossing die werkt voor 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 ;

Voorbeeld:

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


  1. Hoe paginering te maken met PDO PHP

  2. Een externe sleutel maken in SQL Server (T-SQL-voorbeelden)

  3. Een aangepaste SQL Server Docker-afbeelding maken bovenop de officiële afbeelding

  4. MySQL in 2018:What's in 8.0 en andere observaties