您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

对MySQL 4(非5)中的逗号分隔列求和

对MySQL 4(非5)中的逗号分隔列求和

为了进行这种不平凡的字符串操作,您需要使用存储过程,对于MysqL,该存储过程仅在6年前的5.0版中出现。

MysqL 4现在很旧,分支机构4.1的最新版本是4.1.25,在2008年。它不再受支持。大多数Linux发行版不再提供它。确实是时候升级了。

这是适用于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 ;

例:

MysqL> SELECT SUM_OF_LIST("5,2.1") AS Result;
+--------+
| Result |
+--------+
|    7.1 |
+--------+
MySQL 2022/1/1 18:13:46 有557人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶