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
Lepaskan: 2024-12-18 03:24:17
asal
910 orang telah melayarinya

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, '');
Salin selepas log masuk

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 $$
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan