sql >> Databáze >  >> RDS >> Mysql

Sečtení sloupce odděleného čárkou v MySQL 4 (ne 5)

Chcete-li provést tento druh netriviálních manipulací s řetězci, musíte použít uložené procedury, které se pro MySQL objevily teprve před 6 lety, ve verzi 5.0.

MySQL 4 je nyní velmi stará, poslední verze z větve 4.1 byla 4.1.25 z roku 2008. Již není podporována. Většina linuxových distribucí jej již neposkytuje. Je opravdu čas na upgrade.

Zde je řešení, které funguje pro 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 ;

Příklad:

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


  1. Vytvořit booleovský sloupec v MySQL s false jako výchozí hodnotou?

  2. Jak v PostgreSQL vložit data pomocí příkazu COPY?

  3. Dynamické vytváření sloupců z dat řádků pomocí Select in BigQuery

  4. Databáze SQL Server Importers z celého světa kompatibilní s přístupem