sql >> Database teknologi >  >> RDS >> Mysql

Opsummering af en kommasepareret kolonne i MySQL 4 (ikke 5)

For at udføre denne form for ikke-trivielle strengmanipulationer skal du bruge lagrede procedurer, som for MySQL kun dukkede op for 6 år siden, i version 5.0.

MySQL 4 er nu meget gammel, den seneste version fra branch 4.1 var 4.1.25, i 2008. Den understøttes ikke længere. De fleste Linux-distributioner giver det ikke længere. Det er virkelig tid til at opgradere.

Her er en løsning, der virker til 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 ;

Eksempel:

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


  1. Løsning af MySQL-fejl Deadlock fundet, når du forsøger at få lås; prøv at genstarte transaktionen

  2. Er der en måde at køre MySQL in-memory for JUnit test cases?

  3. forskel mellem NLS_NCHAR_CHARACTERSET og NLS_CHARACTERSET for Oracle

  4. Sådan opretter du transaktionsreplikering