Rumah > pembangunan bahagian belakang > tutorial php > Bagaimanakah Saya Boleh Mendapatkan Ralat Pertanyaan PDO Prepare() dalam PHP?

Bagaimanakah Saya Boleh Mendapatkan Ralat Pertanyaan PDO Prepare() dalam PHP?

Barbara Streisand
Lepaskan: 2024-12-06 22:40:12
asal
171 orang telah melayarinya

How Can I Retrieve PDO Prepare() Query Errors in PHP?

Mendapatkan Ralat Pertanyaan daripada prepare() dalam PDO PHP

Apabila menggunakan PDO PHP untuk menyediakan pertanyaan, adalah penting untuk menyemak sebarang potensi kesilapan. Secara lalai, PDO tidak membuang pengecualian untuk ralat yang dihadapi semasa penyediaan pertanyaan. Untuk mendayakan pengendalian ralat, anda boleh memanfaatkan atribut PDO::ATTR_ERRMODE.

Penyelesaian

  • Tetapkan PDO::ATTR_ERRMODE kepada PDO::ERRMODE_EXCEPTION : Dengan menetapkan atribut ini, prepare() akan membuang pengecualian jika an ralat berlaku.
  • Lumpuhkan PDO::ATTR_EMULATE_PREPARES: Untuk memastikan pelayan MySQL memproses pertanyaan semasa prepare(), lumpuhkan atribut ini. Emulasi kadangkala menghalang pelayan daripada mengesan ralat sehingga pelaksanaan pertanyaan.

Contoh:

$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

Jika pertanyaan yang disediakan mengandungi sintaks yang tidak sah, PDO akan membuang pengecualian dengan maklumat berikut:

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

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mendapatkan Ralat Pertanyaan PDO Prepare() dalam PHP?. 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