为了进行这种不平凡的字符串操作,您需要使用存储过程,对于MysqL,该存储过程仅在6年前的5.0版中出现。
MysqL 4现在很旧,分支机构4.1的最新版本是4.1.25,在2008年。它不再受支持。大多数Linux发行版不再提供它。确实是时候升级了。
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 |
+--------+