Rumah pembangunan bahagian belakang masalah PHP Apakah kegunaan php prepare

Apakah kegunaan php prepare

Jan 24, 2022 am 10:24 AM
php prepare

Dalam PHP, "PDO::prepare" bermaksud menyediakan pernyataan untuk dilaksanakan dan mengembalikan objek pernyataan adalah seperti "PDO::prepare(rentetan $statement, array $driver_options = array. ()) ".

Apakah kegunaan php prepare

Persekitaran pengendalian artikel ini: sistem Windows 7, versi PHP 8, komputer DELL G3

Apakah kegunaan php sediakan?

PDO::sediakan

(PHP 5 >= 5.1.0, PHP 7, PHP 8, PHP 8,PECL pdo >= 0.1 .0)

PDO::prepare — Sediakan pernyataan untuk dilaksanakan dan kembalikan objek pernyataan

Penerangan

public PDO::prepare(string $statement, array $driver_options = array()): PDOStatement
Salin selepas log masuk

Sediakan untuk PDOStatement::execute() kaedah pernyataan SQL dilaksanakan. Templat pernyataan boleh mengandungi sifar atau lebih penanda ruang letak parameter dalam bentuk nama (:nama) atau tanda soal (?), yang akan digantikan dengan data sebenar apabila ia dilaksanakan. Dalam templat pernyataan yang sama, borang yang dinamakan dan borang tanda soal tidak boleh digunakan pada masa yang sama; hanya satu daripada borang parameter boleh dipilih. Sila gunakan borang parameter untuk mengikat data yang dimasukkan oleh pengguna, dan jangan sambung rentetan rentetan secara langsung ke dalam pertanyaan.

Apabila memanggil PDOStatement::execute(), nama tanda pemegang tempat parameter untuk setiap nilai mestilah unik. Melainkan mod emulasi didayakan, parameter dengan nama yang sama tidak boleh digunakan dalam pernyataan yang sama.

Nota:

Pemegang tempat parameter hanya boleh memaparkan data lengkap secara literal. Ia tidak boleh menjadi sebahagian daripada literal, kata kunci, pengecam atau mana-mana skop sewenang-wenangnya yang lain. Contohnya: Anda tidak boleh mengikat berbilang nilai pada satu parameter dan kemudian menggunakan pertanyaan IN() dalam pernyataan SQL.

Jika anda menggunakan parameter yang berbeza dan memanggil pernyataan SQL yang sama beberapa kali melalui PDO::prepare() dan PDOStatement::execute(), prestasi aplikasi akan dipertingkatkan - pemacu boleh membenarkan klien/ pelayan untuk cache pertanyaan dan maklumat Meta. Pada masa yang sama, memanggil PDO::prepare() dan PDOStatement::execute() juga boleh menghalang serangan suntikan SQL tanpa memetik dan melarikan parameter secara manual.

Jika pemacu terbina dalam tidak menyokong parameter, PDO akan mensimulasikan fungsi parameter jika pemandu hanya menyokong salah satu gaya (parameter dinamakan dan parameter tanda soal), ia akan menulis semula secara automatik kepada yang lain; gaya.

注意: The parser used for emulated prepared statements and for rewriting named or question mark style parameters supports the non standard backslash escapes for single- and double quotes. That means that terminating quotes immediately preceeded by a backslash are not recognized as such, which may result in wrong detection of parameters causing the prepared statement to fail when it is executed. A work-around is to not use emulated prepares for such SQL queries, and to avoid rewriting of parameters by using a parameter style which is natively supported by the driver.
Salin selepas log masuk

Parameter

penyataan

mestilah templat pernyataan SQL yang sah untuk pelayan pangkalan data sasaran. Tatasusunan

driver_options

mengandungi satu atau lebih pasangan kunci-nilai kunci=>nilai yang menetapkan sifat untuk objek PDOStatement yang dikembalikan. Penggunaan biasa ialah: menetapkan PDO::ATTR_CURSOR kepada PDO::CURSOR_SCROLL akan mendapat kursor boleh tatal. Sesetengah pemandu mempunyai pilihan peringkat pemandu yang ditetapkan semasa penyediaan.

Nilai pulangan

Jika pelayan pangkalan data telah selesai menyediakan pernyataan, PDO::prepare() mengembalikan objek PDOStatement. Jika pelayan pangkalan data tidak dapat menyediakan pernyataan, PDO::prepare() mengembalikan false atau membuang PDOException (bergantung pada pengendali ralat).

Nota:

Pernyataan sediakan dalam mod simulasi tidak berinteraksi dengan pelayan pangkalan data, jadi PDO::prepare() tidak akan menyemak pernyataan tersebut.

Contoh

Contoh #1 templat pernyataan SQL dalam bentuk parameter bernama

<?php
/* 传入数组的值,并执行准备好的语句 */
$sql = &#39;SELECT name, colour, calories
    FROM fruit
    WHERE calories < :calories AND colour = :colour&#39;;
$sth = $dbh->prepare($sql, array(PDO::ATTR_CURSOR => PDO::CURSOR_FWDONLY));
$sth->execute(array(&#39;:calories&#39; => 150, &#39;:colour&#39; => &#39;red&#39;));
$red = $sth->fetchAll();
$sth->execute(array(&#39;:calories&#39; => 175, &#39;:colour&#39; => &#39;yellow&#39;));
$yellow = $sth->fetchAll();
?>
Salin selepas log masuk

Contoh #2 templat pernyataan SQL dalam bentuk tanda soal

<?php
/* 传入数组的值,并执行准备好的语句 */
$sth = $dbh->prepare(&#39;SELECT name, colour, calories
    FROM fruit
    WHERE calories < ? AND colour = ?&#39;);
$sth->execute(array(150, &#39;red&#39;));
$red = $sth->fetchAll();
$sth->execute(array(175, &#39;yellow&#39;));
$yellow = $sth->fetchAll();
?>
Salin selepas log masuk

Pembelajaran yang disyorkan: "Tutorial Video PHP"

Atas ialah kandungan terperinci Apakah kegunaan php prepare. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Konfigurasi Projek CakePHP Konfigurasi Projek CakePHP Sep 10, 2024 pm 05:25 PM

Dalam bab ini, kita akan memahami Pembolehubah Persekitaran, Konfigurasi Umum, Konfigurasi Pangkalan Data dan Konfigurasi E-mel dalam CakePHP.

Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 membawa beberapa ciri baharu, peningkatan keselamatan dan peningkatan prestasi dengan jumlah penamatan dan penyingkiran ciri yang sihat. Panduan ini menerangkan cara memasang PHP 8.4 atau naik taraf kepada PHP 8.4 pada Ubuntu, Debian, atau terbitan mereka

Tarikh dan Masa CakePHP Tarikh dan Masa CakePHP Sep 10, 2024 pm 05:27 PM

Untuk bekerja dengan tarikh dan masa dalam cakephp4, kami akan menggunakan kelas FrozenTime yang tersedia.

CakePHP Bekerja dengan Pangkalan Data CakePHP Bekerja dengan Pangkalan Data Sep 10, 2024 pm 05:25 PM

Bekerja dengan pangkalan data dalam CakePHP adalah sangat mudah. Kami akan memahami operasi CRUD (Buat, Baca, Kemas Kini, Padam) dalam bab ini.

Muat naik Fail CakePHP Muat naik Fail CakePHP Sep 10, 2024 pm 05:27 PM

Untuk mengusahakan muat naik fail, kami akan menggunakan pembantu borang. Di sini, adalah contoh untuk muat naik fail.

Penghalaan CakePHP Penghalaan CakePHP Sep 10, 2024 pm 05:25 PM

Dalam bab ini, kita akan mempelajari topik berikut yang berkaitan dengan penghalaan ?

Bincangkan CakePHP Bincangkan CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP ialah rangka kerja sumber terbuka untuk PHP. Ia bertujuan untuk menjadikan pembangunan, penggunaan dan penyelenggaraan aplikasi lebih mudah. CakePHP adalah berdasarkan seni bina seperti MVC yang berkuasa dan mudah difahami. Model, Pandangan dan Pengawal gu

Pengesah Mencipta CakePHP Pengesah Mencipta CakePHP Sep 10, 2024 pm 05:26 PM

Pengesah boleh dibuat dengan menambah dua baris berikut dalam pengawal.

See all articles