Apabila cuba menggunakan ungkapan biasa untuk memilih hasil daripada jadual MySQL, anda mungkin menghadapi ralat menyatakan "#1139 - Mendapat ralat 'pengendali pengulangan tidak sah' daripada regexp." Kesilapan ini timbul daripada penggunaan '?' pengkuantiti dalam ungkapan biasa MySQL.
Pelaksanaan ungkapan biasa MySQL mengikut piawaian POSIX 1003.2, yang tidak menyokong '?' pengkuantiti sebagai pengubah suai malas (tidak tamak) untuk pengkuantiti bintang dan tambah (cth., ? dan *?).
Untuk menyelesaikan ralat ini, gantikan '?' pengkuantiti dengan rakan sejawatnya yang tamak. Sebagai contoh, daripada menggunakan '?src="http://www', gunakan 'src="http://www' untuk memadankan sebarang bilangan aksara sebelum "src="http:// www".
Selain itu, untuk mengelakkan padanan corak yang tidak diingini (cth., beberapa gaya/" src="a.png">), anda boleh menggunakan kelas aksara yang dinafikan seperti '1*src="http://www''. Ini sepadan dengan kejadian ') sebelum ungkapan 'src="http://www'.
Ingat, petikan berganda ('") tidak perlu melarikan diri dan pengkuantiti .* tersirat pada permulaan ungkapan biasa.
Atas ialah kandungan terperinci Mengapa MySQL Melemparkan Ralat Regex \'Operator Ulangan Tidak Sah\' dan Bagaimana Saya Boleh Membetulkannya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!