PHP中PDO的错误处理_PHP
面向对象的方式
先看看如果连接错误等的处理,PHP中PDO的错误处理,使用面向对象的方式来处理:
复制代码 代码如下:
try {
$db = new PDO('mysql:host=localhost;dbname=test', $user, $pass);
$db = null;
} catch (PDOException $e) {
print "Error: " . $e->getMessage() . "
";
die();
}
?>
这里利用我们PHP 5面向对象的异常处理特征,如果里面有异常的话就初始化调用PDOException来初始化一个异常类。
PDOException异常类的属性结构:
复制代码 代码如下:
class PDOException extends Exception
{
public $errorInfo = null; // 错误信息,可以调用 PDO::errorInfo() 或 PDOStatement::errorInfo()来访问
protected $message; // 异常信息,可以试用 Exception::getMessage() 来访问
protected $code; // SQL状态错误代码,可以使用 Exception::getCode() 来访问
}
?>
这个异常处理类是集成PHP 5内置的异常处理类,我们简单的看一下PHP 5内置的异常处理类结构:
复制代码 代码如下:
class Exception
{
// 属性
protected $message = 'Unknown exception'; // 异常信息
protected $code = 0; // 用户自定义异常代码
protected $file; // 发生异常的文件名
protected $line; // 发生异常的代码行号
// 方法
final function getMessage(); // 返回异常信息
final function getCode(); // 返回异常代码
final function getFile(); // 返回发生异常的文件名
final function getLine(); // 返回发生异常的代码行号
final function getTrace(); // backtrace() 数组
final function getTraceAsString(); // 已格成化成字符串的 getTrace() 信息
}
?>
相应的,在代码中可以合适的调用 getFile() 和 getLine() 来进行错误定位,更方便的进行调试。
使用面向过程的方法
先看代码:
复制代码 代码如下:
$db = new PDO('mysql:host=localhost;dbname=test', $user, $pass);
$rs = $db->query("SELECT aa,bb,cc FROM foo");
if ($db->errorCode() != '00000'){
print_r($db->errorInfo());
exit;
}
$arr = $rs->fetchAll();
print_r($arr);
$db = null;
?>
PDO和PDOStatement对象有errorCode() 和 errorInfo() 方法,如果没有任何错误, errorCode() 返回的是: 00000 ,否则就会返回一些错误代码。errorInfo() 返回的一个数组,包括PHP定义的错误代码和MySQL的错误代码和错误信息,数组结构如下:
Array
(
[0] => 42S22
[1] => 1054
[2] => Unknown column 'aaa' in 'field list'
)
每次执行查询以后,errorCode() 的结果都是最新的,所以我们可以很容易自己控制错误信息显示。
在使用PDO进行那个PHP和数据库开发过程中,如果再碰到错误咋办?按照上面的方式处理吧。
11.3.4 PDO的错误处理
PDO提供了两个获得程序中的错误信息的方法,一个是errorCode()方法;另一个是errorInfo()方法。
1.errorCode()方法
errorCode()方法用于获取在操作数据库句柄时所发生的错误代码,这些错误代码被称为SQLSTATE代码,该方法的语法格式如下:
01 string errorCode ( void ) errorCode()方法的返回值为一个SQLSTATE,SQLSTATE是由5个数字和字母组成的代码。下面是使用errorCode()方法的示例:
【程序11-17】光盘\code\11\pdo\errorCode.php
复制代码 代码如下:
$dsn = 'mysql:dbname=shop;host=localhost';
$user_name = 'root';
$user_psw = 'root';
$pdo = new PDO($dsn, $user_name, $user_psw);
$pdo->exec("update mytable set age=28 where id=1 ");//表mytable不存在
echo "errorCode为: ".$pdo->errorCode();
?>
上述代码输出的错误代码如图11-13所示。
2.errorInfo()方法
errorInfo()方法用于获得操作数据库句柄时所发生的错误信息,该方法的语法格式如下:
01 array errorInfo ( void ) errorInfo()方法的返回值为一个数组,该数组里面包含了相关的错误信息,使用errorInfo()方法的示例代码如下:
【程序11-18】光盘\code\11\pdo\errorInfo.php
复制代码 代码如下:
$dsn = 'mysql:dbname=shop;host=localhost';
$user_name = 'root';
$user_psw = 'root';
$pdo = new PDO($dsn, $user_name, $user_psw);
$pdo->exec("update mytable set age=28 where id=1 ");//表mytable不存在
echo "errorInfo为: ";
print_r($pdo->errorInfo());
?>
上面代码输出的错误信息如图11-14所示。

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Gunakan middleware untuk meningkatkan pengendalian ralat dalam fungsi Go: Memperkenalkan konsep middleware, yang boleh memintas panggilan fungsi dan melaksanakan logik tertentu. Buat perisian tengah pengendalian ralat yang membungkus logik pengendalian ralat dalam fungsi tersuai. Gunakan middleware untuk membalut fungsi pengendali supaya logik pengendalian ralat dilakukan sebelum fungsi dipanggil. Mengembalikan kod ralat yang sesuai berdasarkan jenis ralat, улучшениеобработкиошибоквфункциях Goспомощьюпромежуточногопрограммногообеспечения.Оноспечечения.Онооть познамочения. ошибо

Dalam C++, pengendalian pengecualian mengendalikan ralat dengan anggun melalui blok try-catch Jenis pengecualian biasa termasuk ralat masa jalan, ralat logik dan ralat luar sempadan. Ambil pengendalian ralat pembukaan fail sebagai contoh Apabila program gagal membuka fail, ia akan membuang pengecualian dan mencetak mesej ralat dan mengembalikan kod ralat melalui blok tangkapan, dengan itu mengendalikan ralat tanpa menamatkan program. Pengendalian pengecualian memberikan kelebihan seperti pemusatan pengendalian ralat, penyebaran ralat dan keteguhan kod.

Ralat pengendalian dan log masuk dalam reka bentuk kelas C++ termasuk: Pengendalian pengecualian: menangkap dan mengendalikan pengecualian, menggunakan kelas pengecualian tersuai untuk memberikan maklumat ralat khusus. Kod ralat: Gunakan integer atau penghitungan untuk mewakili keadaan ralat dan mengembalikannya dalam nilai pulangan. Penegasan: Sahkan syarat pra dan pasca, dan buang pengecualian jika ia tidak dipenuhi. Pengelogan perpustakaan C++: pengelogan asas menggunakan std::cerr dan std::clog. Perpustakaan pengelogan luaran: Integrasikan perpustakaan pihak ketiga untuk ciri lanjutan seperti penapisan tahap dan putaran fail log. Kelas log tersuai: Buat kelas log anda sendiri, abstrak mekanisme asas dan sediakan antara muka biasa untuk merekodkan tahap maklumat yang berbeza.

Alat dan perpustakaan pengendalian ralat terbaik dalam PHP termasuk: Kaedah terbina dalam: set_error_handler() dan error_get_last() Kit alat pihak ketiga: Whoops (penyahpepijat dan pemformatan ralat) Perkhidmatan pihak ketiga: Sentry (pelaporan dan pemantauan ralat) Pihak ketiga perpustakaan: PHP-error-handler (pengelogan ralat tersuai dan jejak tindanan) dan Monolog (pengendali pengelogan ralat)

Dalam fungsi Go, pengendalian ralat tak segerak menggunakan saluran ralat untuk menghantar ralat daripada goroutin secara tak segerak. Langkah-langkah khusus adalah seperti berikut: Cipta saluran ralat. Mulakan goroutine untuk melaksanakan operasi dan menghantar ralat secara tidak segerak. Gunakan pernyataan pilih untuk menerima ralat daripada saluran. Mengendalikan ralat secara tidak segerak, seperti mencetak atau mengelog mesej ralat. Pendekatan ini meningkatkan prestasi dan kebolehskalaan kod serentak kerana pengendalian ralat tidak menyekat urutan panggilan dan pelaksanaan boleh dibatalkan.

Amalan terbaik untuk pengendalian ralat dalam Go termasuk: menggunakan jenis ralat, sentiasa mengembalikan ralat, menyemak ralat, menggunakan pulangan berbilang nilai, menggunakan ralat sentinel dan menggunakan pembalut ralat. Contoh praktikal: Dalam pengendali permintaan HTTP, jika ReadDataFromDatabase mengembalikan ralat, kembalikan respons ralat 500.

Dalam Golang, pembalut ralat membolehkan anda membuat ralat baharu dengan menambahkan maklumat kontekstual kepada ralat asal. Ini boleh digunakan untuk menyatukan jenis ralat yang dilemparkan oleh perpustakaan atau komponen yang berbeza, memudahkan penyahpepijatan dan pengendalian ralat. Langkah-langkahnya adalah seperti berikut: Gunakan fungsi ralat. Balut untuk membalut ralat asal kepada ralat baharu. Ralat baharu mengandungi maklumat kontekstual daripada ralat asal. Gunakan fmt.Printf untuk mengeluarkan ralat yang dibalut, memberikan lebih konteks dan kebolehtindakan. Apabila mengendalikan pelbagai jenis ralat, gunakan fungsi ralat. Balut untuk menyatukan jenis ralat.

Dalam ujian unit fungsi Go, terdapat dua strategi utama untuk pengendalian ralat: 1. Wakilkan ralat sebagai nilai khusus jenis ralat, yang digunakan untuk menegaskan nilai yang dijangkakan 2. Gunakan saluran untuk menghantar ralat kepada fungsi ujian; yang sesuai untuk menguji kod serentak. Dalam kes praktikal, strategi nilai ralat digunakan untuk memastikan fungsi mengembalikan 0 untuk input negatif.
