Rumah > pembangunan bahagian belakang > tutorial php > Bagaimana Saya Boleh Meningkatkan Fungsi Sisipan/Kemas Kini MySQL Saya Menggunakan Penyata Disediakan PDO?

Bagaimana Saya Boleh Meningkatkan Fungsi Sisipan/Kemas Kini MySQL Saya Menggunakan Penyata Disediakan PDO?

Mary-Kate Olsen
Lepaskan: 2024-11-23 09:24:43
asal
884 orang telah melayarinya

How Can I Improve My MySQL Insert/Update Function Using PDO Prepared Statements?

Sisipkan/Kemas kini Fungsi Pembantu Menggunakan PDO

Penyata Disediakan PDO untuk Memasukkan Data

Fungsi pembantu yang disediakan, dbSet, menghasilkan pernyataan SET untuk digunakan dengan pemacu MySQL tradisional tetapi tidak mempunyai sokongan untuk pernyataan yang disediakan oleh PDO. Untuk menangani perkara ini, versi diubah suai fungsi boleh digunakan, memanfaatkan faedah PDO.

Fungsi Pembantu Diubahsuai

Fungsi dbSet yang dikemas kini kini memerlukan pelbagai nama medan dan rujukan kepada tatasusunan nilai yang sepadan. Ia membina pernyataan SET dengan ruang letak untuk setiap medan dan menambah nilai pada tatasusunan nilai.

function dbSet($fields, &$values) {
    $set = '';
    $values = array();

    foreach ($fields as $field) {
        if (isset($_POST[$field])) {
            $set .= "`$field` = ?,";
            $values[] = $_POST[$field];
        }
    }

    return rtrim($set, ',');
}
Salin selepas log masuk

Contoh Penggunaan:

$fields = explode(" ","name surname lastname address zip fax phone date");
$_POST['date'] = $_POST['y']."-".$_POST['m']."-"$_POST['d'];

$query  = "UPDATE $table SET ".dbSet($fields, $values).", stamp=NOW() WHERE>
Salin selepas log masuk

Kelebihan daripada PDO Disediakan Pernyataan:

  • Keselamatan: Menghalang suntikan SQL dengan menggunakan ruang letak.
  • Kecekapan: Menyediakan pertanyaan sekali, mengurangkan pangkalan data atas kepala.
  • Ketekalan: Memastikan pemformatan data dan penukaran jenis yang konsisten.

Penyelesaian Alternatif: Pemetaan Perhubungan Objek (ORM)

Pertimbangkan untuk menggunakan ORM seperti Doktrin ORM, yang memudahkan populasi data dan menghapuskan keperluan untuk membina pertanyaan manual.

$table = new Table();
$table->fromArray($_POST);
$table->save();
Salin selepas log masuk

Pendekatan ini mengautomasikan proses memetakan sifat ke medan pangkalan data berdasarkan kelas entiti yang ditentukan.

Atas ialah kandungan terperinci Bagaimana Saya Boleh Meningkatkan Fungsi Sisipan/Kemas Kini MySQL Saya Menggunakan Penyata Disediakan PDO?. 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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan