Rumah >pangkalan data >tutorial mysql >Bagaimana Mengendalikan Pengecualian PDO dalam PHP dan Mencegah Status \'Null\'?

Bagaimana Mengendalikan Pengecualian PDO dalam PHP dan Mencegah Status \'Null\'?

Linda Hamilton
Linda Hamiltonasal
2024-10-31 10:33:011127semak imbas

How to Handle PDO Exceptions in PHP and Prevent

Mengendalikan Pengecualian PDO

Apabila bekerja dengan PDO dalam PHP, pengendalian ralat boleh menjadi penting untuk penyahpepijatan dan memastikan integriti data. Walau bagaimanapun, kod yang anda berikan tidak mengendalikan ralat dengan betul, membawa kepada status "null" dan ralat tidak dilaporkan.

Isu kritikal ialah PDO tidak membuang pengecualian secara lalai. Untuk mendayakan pengendalian pengecualian, anda mesti menetapkan atribut mod ralat secara eksplisit:

$connection->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

Setelah mod ralat ditetapkan, blok tangkapan boleh menangkap dan memaparkan mesej ralat terperinci:

try {
    // ... your code here ...
} catch (PDOException $e) {
    print $e->getMessage();
}

Selain menetapkan mod ralat, kod anda harus menggunakan parameter bind dengan jenis data yang sesuai untuk keselamatan dan keserasian:

$statement->bindParam(':user_id', trim($id), PDO::PARAM_INT);
$statement->bindParam(':name', trim($name), PDO::PARAM_STR);
$statement->bindParam(':url', trim($url), PDO::PARAM_STR);
$statement->bindParam(':country', trim($country), PDO::PARAM_STR, 2);

Dengan pengendalian pengecualian yang betul dan jenis data yang betul, kod anda kini harus dilaksanakan dan dikembalikan status yang betul apabila berjaya atau gagal.

Atas ialah kandungan terperinci Bagaimana Mengendalikan Pengecualian PDO dalam PHP dan Mencegah Status \'Null\'?. 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