Bagaimana untuk Melarikan Diri Watak Khas dalam Corak SEPERTI PostgreSQL?

Mary-Kate Olsen
Lepaskan: 2024-11-23 00:22:13
asal
370 orang telah melayarinya

How to Escape Special Characters in PostgreSQL LIKE Patterns?

Meloloskan diri daripada Aksara Khas dalam Corak LIKE PostgreSQL

Meloloskan diri daripada aksara khas dalam corak LIKE adalah penting untuk memastikan padanan yang tepat. Sebagai contoh, pertimbangkan senario di mana anda mencari baris di mana lajur nama bermula dengan rentetan yang disediakan pengguna, seperti "rompak%". Walau bagaimanapun, jika input pengguna termasuk aksara khas seperti "_," ia akan menghasilkan positif palsu.

Mekanisme Melarikan Diri

PostgreSQL membolehkan anda melarikan diri daripada aksara khas menggunakan garis miring ke belakang () atau aksara melarikan diri yang ditentukan pengguna yang ditentukan dengan klausa ESCAPE. Untuk memadankan watak istimewa secara literal, anda mesti melarikan diri dua kali.

Contoh

Untuk memadankan "rob_" secara literal, anda akan menggunakan corak LIKE berikut:

WHERE name LIKE 'rob^^%'
Salin selepas log masuk

Sebagai alternatif, anda boleh menggunakan klausa melarikan diri dan menentukan melarikan diri alternatif watak:

WHERE name LIKE 'rob_%node1^^node2.uucp@%' ESCAPE '^'
Salin selepas log masuk

Ini akan sepadan dengan "john%node1^node2.uccp@" diikuti dengan mana-mana aksara.

Pertimbangan

  • Watak lalai melarikan diri ialah garis miring ke belakang, tetapi ia digunakan untuk tujuan lain apabila standard_conforming_strings MATI.
  • Meloloskan diri daripada aksara khas juga terpakai pada pernyataan SQL dinamik yang dibina daripada input pengguna, dalam hal ini ia harus dilakukan di sebelah pelayan untuk mengelakkan suntikan SQL.
  • Menggunakan ruang letak untuk penggantian pembolehubah memastikan kedua-duanya padanan yang tepat dan keselamatan.

SQL Generik Kenyataan

Berikut ialah pernyataan SQL generik yang boleh digunakan dengan atau tanpa standard_conforming_strings HIDUP, menggunakan penggantian aksara melarikan diri sebelah pelayan:

SELECT * FROM USERS WHERE name LIKE replace(replace(replace(,'^','^^'),'%','^%'),'_','^_') ||'%' ESCAPE '^'
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimana untuk Melarikan Diri Watak Khas dalam Corak SEPERTI PostgreSQL?. 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