我正在编写一个查询,该查询从一个表中选择数据到另一个表中,需要移动的列之一是DECIMAL列。由于我无法控制的原因,“源”列有时可以是用逗号分隔的数字列表。有没有一种优雅的sql唯一方法可以做到这一点?
例如:
源列
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 | +--------+