Rumah >pangkalan data >tutorial mysql >Bolehkah Ungkapan Biasa Menghuraikan Rentetan Dipisahkan Koma ke dalam Jadual Sementara MySQL?

Bolehkah Ungkapan Biasa Menghuraikan Rentetan Dipisahkan Koma ke dalam Jadual Sementara MySQL?

Barbara Streisand
Barbara Streisandasal
2024-12-18 03:24:17850semak imbas

Can Regular Expressions Parse Comma-Separated Strings into MySQL Temporary Tables?

Menggunakan RegEx untuk Menghuraikan Rentetan Dipisahkan Koma ke dalam Jadual MySQL Temp

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn