Soalan:
Adakah mungkin untuk menghuraikan rentetan dipisahkan koma ke dalam jadual MySQL sementara menggunakan biasa ungkapan?
Jawapan:
Walaupun MySQL tidak mempunyai fungsi terbina dalam untuk pemisahan rentetan, pelbagai penyelesaian wujud. Satu pendekatan melibatkan fungsi tersuai dan mekanisme gelung untuk memecahkan rentetan kepada komponennya.
Fungsi Tersuai untuk Pemisahan Rentetan:
CREATE FUNCTION SPLIT_STR( x VARCHAR(255), delim VARCHAR(12), pos INT ) RETURNS VARCHAR(255) RETURN REPLACE(SUBSTRING(SUBSTRING_INDEX(x, delim, pos), LENGTH(SUBSTRING_INDEX(x, delim, pos -1)) + 1), delim, '');
Gelung dan Penambahan Fungsi Tersuai:
DELIMITER $$ CREATE PROCEDURE ABC(fullstr) BEGIN DECLARE a INT Default 0 ; DECLARE str VARCHAR(255); simple_loop: LOOP SET a=a+1; SET str=SPLIT_STR(fullstr,"|",a); IF str='' THEN LEAVE simple_loop; END IF; #Do Inserts into temp table here with str going into the row insert into my_temp_table values (str); END LOOP simple_loop; END $$
Pendekatan ini membolehkan anda menghuraikan pembahagian rentetan dan masukkan komponen secara dinamik ke dalam jadual sementara menggunakan keupayaan gelung MySQL.
Atas ialah kandungan terperinci Bolehkah Ungkapan Biasa Menghuraikan Rentetan Dipisahkan Koma ke dalam Jadual Sementara MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!