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.
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.
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!