Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Dapatkan dan Mengendalikan Ralat Pertanyaan daripada Kaedah `prepare()` PDO?

Bagaimanakah Saya Boleh Dapatkan dan Mengendalikan Ralat Pertanyaan daripada Kaedah `prepare()` PDO?

Susan Sarandon
Susan Sarandonasal
2024-12-11 18:09:11445semak imbas

How Can I Retrieve and Handle Query Errors from PDO's `prepare()` Method?

Mendapatkan Ralat Pertanyaan daripada prepare() dalam PHP PDO

Apabila menyediakan pertanyaan menggunakan PDO, adalah penting untuk mendapatkan semula ralat yang berkaitan. Ini amat berguna untuk tujuan penyahpepijatan atau mengendalikan interaksi pangkalan data yang tidak dijangka.

Masalahnya

Pertimbangkan coretan kod PHP berikut:

$st = $db->prepare("SELECT * FROM c6ode");

Dalam kes ini, jika pertanyaan mengandungi sebarang ralat (seperti jadual yang tidak wujud), mungkin tidak pasti cara untuk mendapatkan dan mengendalikannya ralat.

Penyelesaian

Untuk mendapatkan semula ralat pertanyaan daripada kaedah prepare(), adalah perlu untuk mengkonfigurasi PDO untuk membuang pengecualian pada ralat. Ini dicapai dengan menetapkan atribut PDO::ATTR_ERRMODE kepada PDO::ERRMODE_EXCEPTION.

Selain itu, untuk memastikan pelayan MySQL mengesahkan pertanyaan semasa peringkat penyediaan, adalah penting untuk melumpuhkan ciri PDO::ATTR_EMULATE_PREPARES . Ini menghalang pelayan daripada menangguhkan pengesahan pertanyaan sehingga pelaksanaan.

Untuk menggambarkan, pertimbangkan kod berikut:

<?php
$pdo = new PDO('mysql:host=localhost;dbname=test;charset=utf8', 'localonly', 'localonly');
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
$pdo->prepare('INSERT INTO DoesNotExist (x) VALUES (?)');

Apabila kod ini dilaksanakan, pengecualian akan dilemparkan dengan butiran berikut:

SQLSTATE[42S02]: Base table or view not found: 1146 Table 'test.doesnotexist' doesn't exist

Dengan mengkonfigurasi PDO dengan sewajarnya, ia menjadi mungkin untuk menangkap dan mengendalikan ralat pertanyaan dengan berkesan, memastikan penyahpepijatan yang cekap dan interaksi pangkalan data.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Dapatkan dan Mengendalikan Ralat Pertanyaan daripada Kaedah `prepare()` PDO?. 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