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
Lepaskan: 2024-12-11 18:09:11
asal
435 orang telah melayarinya

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");
Salin selepas log masuk

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 (?)');
Salin selepas log masuk

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
Salin selepas log masuk

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!

sumber:php.cn
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