Rumah >pangkalan data >tutorial mysql >Bagaimanakah Anda Boleh Merujuk Kumpulan yang Ditangkap dalam Ungkapan Biasa MySQL?

Bagaimanakah Anda Boleh Merujuk Kumpulan yang Ditangkap dalam Ungkapan Biasa MySQL?

Susan Sarandon
Susan Sarandonasal
2024-11-03 14:24:03302semak imbas

How Can You Reference Captured Groups in MySQL Regular Expressions?

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!

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