Menjumlahkan Lajur Dipisahkan Koma dalam MySQL 4
Seorang pengguna telah menghadapi situasi di mana data dalam lajur sumber boleh dibentangkan sebagai dipisahkan koma senarai nombor. Objektifnya adalah untuk mengubah data ini menjadi lajur destinasi di mana nombor dijumlahkan. Cabaran ini timbul apabila menggunakan MySQL versi 4, yang tidak mempunyai keupayaan yang diperkenalkan dalam MySQL 5.0.
Penyelesaian
Malangnya, MySQL 4 tidak menyokong prosedur tersimpan, yang penting untuk tugas manipulasi rentetan yang rumit seperti yang dibentangkan. Oleh itu, menaik taraf kepada MySQL 5.0 atau lebih baru ialah penyelesaian yang disyorkan.
Penyelesaian MySQL 5.0
Untuk MySQL versi 5.0 dan ke atas, penyelesaian berikut boleh digunakan:
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 ;
Contoh Penggunaan:
mysql> SELECT SUM_OF_LIST("5,2.1") AS Result; +--------+ | Result | +--------+ | 7.1 | +--------+
Atas ialah kandungan terperinci Bagaimana Menjumlahkan Nombor Dipisahkan Koma dalam Lajur MySQL 4?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!