Rumah >pembangunan bahagian belakang >masalah PHP >Bagaimana untuk mengendalikan ralat dalam PDO untuk pembelajaran pangkalan data PHP?
Dalam artikel sebelumnya, saya membawakan anda " Bagaimana menggunakan PDO untuk mendapatkan hasil pertanyaan dalam pembelajaran pangkalan data PHP? 》, yang memperkenalkan secara terperinci pengetahuan yang berkaitan tentang cara menggunakan PDO untuk mendapatkan hasil pertanyaan Dalam artikel ini, kita akan melihat cara mengendalikan ralat PDO dalam PHP.
Dalam kajian lepas, kita telah belajar untuk mendapatkan hasil pertanyaan melalui PDO, maka kita perlu belajar tentang pengendalian ralat PDO Terdapat dua perolehan dalam PDO The error kaedah mesej dalam program ialah kaedah errorCode()
dan kaedah errorInfo()
masing-masing. Seterusnya, mari kita lihat aplikasi kedua-dua kaedah ini.
Sebelum memahami cara kaedah errorCode() dan kaedah errorInfo() mengendalikan ralat, mari kita lihat dahulu mod pengendalian ralat dalam PDO.
Mod pengendalian ralat PDO
Terdapat tiga mod pengendalian ralat berbeza yang disediakan dalam PDO, yang bukan sahaja memenuhi gaya pengaturcaraan yang berbeza juga boleh melaraskan cara sambungan mengendalikan ralat. Kemudian saya akan memperkenalkan kepada anda tiga kaedah pengendalian ralat yang berbeza ini.
<span style="font-size: 16px;"><code><span style="font-size: 16px;"><strong>PDO::ERRMODE_SILENT</strong></span><span style="font-size: 16px;"><strong> </strong></span>
PDO::ERRMODE_SILENT
PDO::ERRMODE_SILENT
PDO::errorCode()
PDO::errorInfo()
mewakili mod lalai. Dalam kes ini, apabila ralat berlaku, PDO hanya akan menetapkan kod ralat tanpa melakukan sebarang operasi lain Anda juga boleh menggunakan kaedah
dan
Apa yang perlu kita ambil perhatian ialah jika ralat berlaku kerana objek pernyataan panggilan, maka kaedah PDOStatement::errorCode() atau PDOStatement::errorInfo() objek ini boleh dipanggil. Jika ralat berlaku kerana memanggil objek pangkalan data, anda boleh memanggil kaedah PDOStatement::errorCode() atau PDOStatement::errorInfo() pada objek pangkalan data. <span style="font-size: 16px;"><strong>PDO::ERRMODE_WARNING </strong></span><span style="font-size: 16px;"></span>
<span style="font-size: 16px;"><br>PDO::ERRMODE_WARNING </span>
<span style="font-size: 16px;"><strong>PDO::ERRMODE_EXCEPTION </strong></span>
<span style="font-size: 16px;"><code>SQL-92 SQLSTATE
PDO:: ERRMODE_EXCEPTION PDO::errorCode()
SQLSTATE
PDO::errorInfo()
PDO::ERRMODE_EXCEPTION mod juga boleh menetapkan kod ralat Pada pandangan pertama, selain daripada menetapkan kod ralat, PDO juga boleh membuang a Kelas Pengecualian PDOException dan tetapkan sifatnya untuk mencerminkan kod ralat dan mesej ralat. Mod PDO::ERRMODE_EXCEPTION juga sangat berguna apabila menyahpepijat Ia boleh menunjukkan kawasan yang berpotensi bermasalah dalam kod dengan sangat cepat, kerana ia secara berkesan membesarkan titik dalam skrip di mana ralat berlaku.
PDO menggunakan
untuk menyeragamkan rentetan kod ralat dan pemacu PDO yang berbeza bertanggungjawab untuk memetakan kod asli mereka kepada kod SQLSTATE yang sesuai. Kaedah<?php $dsn = 'mysql:dbname=test;host=127.0.0.1'; $user = 'root'; $pwd = 'root'; try { $pdo = new PDO($dsn, $user, $pwd); $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); } catch (PDOException $e) { echo 'Connection failed: ' . $e->getMessage(); } ?>mengembalikan satu kod
tunggal. PDO::setAttribute()
Jika anda memerlukan maklumat yang lebih terperinci tentang ralat ini, PDO turut menyediakan kaedah
$pdo = new PDO($dsn, $user, $pwd, array(PDO::ATTR_ERRMODE => PDO::ERRMODE_WARNING));
Seterusnya kami menggunakan contoh untuk melihat membuat contoh PDO dan menetapkan mod ralat. Contohnya adalah seperti berikut:
<strong><span style="font-size: 20px;">PDO::errorCode()</span></strong>
Dalam contoh di atas, mod ralat ditetapkan melalui kaedah Selain menetapkan mod ralat dalam kaedah ini, mod ralat juga boleh ditetapkan apabila membuat contoh PDO Contohnya adalah seperti berikut:
PDO::errorCode()
Di atas ialah tiga mod pengendalian ralat PDO Seterusnya, mari kita lihat PDO:: kaedah errorCode().
PDO::errorCode() 方法可以返回一个 SQLSTATE,一个由 5 个字母或数字组成的在 ANSI SQL
标准中定义的标识符。 简单可以理解成,一个 SQLSTATE 由前面两个字符的类值和后面三个字符的子类值组成。
接下来我们通过示例来看一下通过 PDO 连接数据库,并通过 errorCode() 方法获取错误代码。
示例如下:
<?php $dsn = 'mysql:dbname=test;host=127.0.0.1'; $user = 'root'; $pwd = 'root'; try { $pdo = new PDO($dsn, $user, $pwd); $sql = 'select * from user'; $res = $pdo -> query($sql); echo 'errorCode 为:'.$pdo -> errorCode().'<br>'; foreach ($res as $key => $value) { echo '序号:'.$value['id'].'; 姓名:'.$value['name'].'; 年龄:'.$value['age'].'; 性别:'.$value['sex'].'<br>'; } } catch (PDOException $e) { echo 'Connection failed: ' . $e->getMessage(); } ?>
输出结果:
上述结果便是通过 errorCode() 方法获取错误代码。接下来我们看一下最后一种方法PDO::errorInfo() 方法。
<strong><span style="font-size: 20px;">PDO::errorInfo() </span></strong>
方法
PDO::errorInfo()
方法与PDO::errorCode()
方法一样都是用于获取操作数据库句柄时所发生的错误信息。
不同的是errorInfo() 方法的返回值为一个数组,它包含了相关的错误信息。
接下来我们通过示例来看一下使用 PDO 中的 query 方法完成数据查询操作,并通过 errorInfo() 方法获取错误信息。
示例如下:
<?php $dsn = 'mysql:dbname=test;host=127.0.0.1'; $user = 'root'; $pwd = 'root'; try { $pdo = new PDO($dsn, $user, $pwd); // $pdo -> setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $sql = 'select * from userr'; $res = $pdo -> query($sql); echo 'errorInfo 为:<br>'; print_r($pdo -> errorInfo()); } catch (PDOException $e) { echo 'Connection failed: ' . $e->getMessage(); } ?>
上述示例中,我们查询了一个不存在的数据库,输出结果:
其中我们需要注意的是:PDO 和 PDOStatement 对象中都有 errorCode() 和 errorInfo() 方法,如果没有任何错误,errorCode() 返回的是 00000;否则就会返回一些错误代码。而 errorInfo() 返回的是一个数组,包括 PHP 定义的错误代码和 MySQL 的错误代码及错误信息。
大家如果感兴趣的话,可以点击《PHP视频教程》进行更多关于PHP知识的学习。
Atas ialah kandungan terperinci Bagaimana untuk mengendalikan ralat dalam PDO untuk pembelajaran pangkalan data PHP?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!