gpt4 book ai didi

mysql - 在 MySQL 4(不是 5)中总结一个逗号分隔的列

转载 作者:行者123 更新时间:2023-11-29 03:34:44 24 4
gpt4 key购买 nike

我正在编写一个查询,从一个表中选择数据到另一个表中,需要移动的列之一是 DECIMAL 列。由于我无法控制的原因,源列有时可以是逗号分隔的数字列表。是否有一种优雅的 sql only 方法可以做到这一点?

例如:

来源专栏

10.2
5,2.1
4

应该产生一个目标列

10.2
7.1
4

顺便说一句,我正在使用 MySQL 4。

最佳答案

要进行这种重要的字符串操作,您需要使用存储过程,对于 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 - 在 MySQL 4(不是 5)中总结一个逗号分隔的列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24149908/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com