Rumah >pangkalan data >tutorial mysql >Bagaimanakah Anda Boleh Merujuk Kumpulan yang Ditangkap dalam Ungkapan Biasa MySQL?
Tangkap Rujukan Kumpulan dalam Ungkapan Biasa MySQL
Apabila bekerja dengan ungkapan biasa dalam MySQL, menangkap kumpulan boleh digunakan untuk mengekstrak bahagian teks. Walau bagaimanapun, tidak seperti kebanyakan bahasa pengaturcaraan lain, MySQL tidak menyediakan tahap sokongan yang sama untuk merujuk kepada kumpulan yang ditangkap dalam penggantian regex berikutnya.
Dalam MySQL 8, fungsi REGEXP_REPLACE memperkenalkan keupayaan untuk merujuk kumpulan tangkapan menggunakan $1, $2, dsb. Contohnya, pertanyaan berikut menggantikan lima aksara pertama rentetan 'stackoverflow' dengan aksara yang tinggal:
<code class="sql">SELECT REGEXP_REPLACE('stackoverflow','(.{5})(.*)',''); -- "overflowstack"</code>
MariaDB juga membenarkan penangkapan dalam REGEXP_REPLACE, tetapi rujukan dibuat menggunakan 1, 2 , dsb.
Walau bagaimanapun, adalah penting untuk ambil perhatian bahawa dalam versi MySQL yang lebih awal, seperti MySQL 5.7 dan sebelumnya, tiada sokongan langsung untuk merujuk kumpulan tangkapan dalam ungkapan biasa. Dalam versi ini, teknik seperti menggantikan keseluruhan padanan dengan rentetan literal atau menggunakan ungkapan biasa serasi Perl (PCRE) melalui pustaka PCRE luaran, diperlukan untuk merujuk kumpulan yang ditangkap.
Atas ialah kandungan terperinci Bagaimanakah Anda Boleh Merujuk Kumpulan yang Ditangkap dalam Ungkapan Biasa MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!