Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Cara Menggunakan Kad Liar dengan Penyata Disediakan PDO: Panduan untuk Mengelakkan Perangkap Biasa?

Cara Menggunakan Kad Liar dengan Penyata Disediakan PDO: Panduan untuk Mengelakkan Perangkap Biasa?

DDD
DDDasal
2024-10-28 13:52:01172semak imbas

How to Use Wildcards with PDO Prepared Statements: A Guide to Avoiding Common Pitfalls?

Penyata Disediakan PDO dengan Sokongan Wildcard

Penyata yang disediakan menawarkan keselamatan dan prestasi yang dipertingkatkan untuk pertanyaan pangkalan data dengan menghalang serangan suntikan SQL. Walau bagaimanapun, menggunakan kad bebas dengan pernyataan yang disediakan boleh menimbulkan cabaran.

Dalam kes anda, anda cuba melaksanakan pertanyaan seperti:

<code class="sql">SELECT * FROM `gc_users` WHERE `name` LIKE '%anyname%'</code>

Anda cuba mengikat parameter dengan '%:name Kaedah %' dan ':name', tetapi kedua-duanya gagal. Begini cara anda boleh menggunakan kad bebas dengan pernyataan yang disediakan:

Menggunakan bindValue:

Anda boleh menggunakan bindValue untuk mengikat parameter kad bebas dengan betul:

<code class="php">$stmt = $dbh->prepare("SELECT * FROM `gc_users` WHERE `name` LIKE :name");
$stmt->bindValue(':name', '%' . $name . '%');
$stmt->execute();</code>

Menggunakan bindParam (Diubah suai):

Selain itu, anda juga boleh menggunakan bindParam dengan sedikit pengubahsuaian:

<code class="php">$name = "%$name%";
$query = $dbh->prepare("SELECT * FROM `gc_users` WHERE `name` like :name");
$query->bindParam(':name', $name);
$query->execute();</code>

Atas ialah kandungan terperinci Cara Menggunakan Kad Liar dengan Penyata Disediakan PDO: Panduan untuk Mengelakkan Perangkap Biasa?. 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