Melucutkan Aksara Bukan Alfanumerik daripada Rentetan dalam MySQL
Masalah:
Apabila membandingkan rentetan dalam MySQL, kecekapan boleh dipertingkatkan dengan mengalih keluar semua aksara bukan abjad angka. Pada masa ini, pelbagai fungsi REPLACE sedang digunakan, tetapi penyelesaian yang lebih cekap dan elegan dicari.
Penyelesaian:
Untuk MySQL 8.0 atau lebih tinggi:
MySQL kini menyokong penggantian Regex, menjadikannya mungkin untuk mengalih keluar aksara bukan abjad angka dengan pernyataan tunggal:
UPDATE {table} SET {column} = REGEXP_REPLACE({column}, '[^0-9a-zÀ-ÿ ]', '')
Untuk MySQL 5.7 atau lebih rendah:
Sokongan Regex tidak tersedia. Fungsi tersuai, 'alphanum,' boleh dibuat untuk melakukan pelucutan aksara:
DROP FUNCTION IF EXISTS alphanum; DELIMITER | CREATE FUNCTION alphanum( str CHAR(255) ) RETURNS CHAR(255) DETERMINISTIC BEGIN DECLARE i, len SMALLINT DEFAULT 1; DECLARE ret CHAR(255) DEFAULT ''; DECLARE c CHAR(1); IF str IS NOT NULL THEN SET len = CHAR_LENGTH( str ); REPEAT BEGIN SET c = MID( str, i, 1 ); IF c REGEXP '[[:alnum:]]' THEN SET ret=CONCAT(ret,c); END IF; SET i = i + 1; END; UNTIL i > len END REPEAT; ELSE SET ret=''; END IF; RETURN ret; END | DELIMITER ;
Fungsi ini kemudiannya boleh digunakan untuk menanggalkan aksara bukan abjad angka daripada rentetan:
select 'This works finally!', alphanum('This works finally!');
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengeluarkan Aksara Bukan Alfanumerik dengan Cekap daripada Rentetan dalam MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!