Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimana untuk mengendalikan ralat dalam PDO untuk pembelajaran pangkalan data PHP?

Bagaimana untuk mengendalikan ralat dalam PDO untuk pembelajaran pangkalan data PHP?

WBOY
WBOYasal
2021-10-28 16:54:022198semak imbas

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.

Bagaimana untuk mengendalikan ralat dalam PDO untuk pembelajaran pangkalan data 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

untuk menyemak penyata dan objek pangkalan data.
  • 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>

  • PDO::ERRMODE_WARNING mod boleh menetapkan kod ralat. Sudah tentu, selain menetapkan kod ralat, PDO juga akan Menghantar mesej, mesej ini ialah mesej E_WARNING yang sangat tradisional. Apabila kami perlu menyahpepijat atau menguji, kami tidak mahu mengganggu program tetapi ingin mengetahui apa yang salah. PDO::ERRMODE_WARNING Sudah tiba masanya untuk mod ini mula dimainkan


<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  = &#39;mysql:dbname=test;host=127.0.0.1&#39;;
    $user = &#39;root&#39;;
    $pwd  = &#39;root&#39;;
    try {
        $pdo = new PDO($dsn, $user, $pwd);
        $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    } catch (PDOException $e) {
        echo &#39;Connection failed: &#39; . $e->getMessage();
    }
?>
mengembalikan satu kod

tunggal. PDO::setAttribute()
Jika anda memerlukan maklumat yang lebih terperinci tentang ralat ini, PDO turut menyediakan kaedah

untuk mengembalikan tatasusunan yang mengandungi kod SQLSTATE, kod ralat pemacu khusus dan rentetan ralat pemacu ini.

Satu lagi kesan mod pengecualian yang sangat berguna ialah anda boleh membina pengendalian ralat anda sendiri dengan lebih jelas daripada amaran gaya PHP tradisional, dan berbanding dengan mod senyap dan secara eksplisit menyemak pengembalian setiap nilai panggilan pangkalan data, corak pengecualian memerlukan kurang kod/bersarang.
$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() Kaedah Kaedah kebanyakannya digunakan untuk mendapatkan kod ralat yang berlaku apabila mengendalikan pangkalan data kod ini dipanggil kod SQLSTATE.

PDO::errorCode() 方法可以返回一个 SQLSTATE,一个由 5 个字母或数字组成的在 ANSI SQL 标准中定义的标识符。 简单可以理解成,一个 SQLSTATE 由前面两个字符的类值和后面三个字符的子类值组成。

接下来我们通过示例来看一下通过 PDO 连接数据库,并通过 errorCode() 方法获取错误代码。

示例如下:

<?php
    $dsn  = &#39;mysql:dbname=test;host=127.0.0.1&#39;;
    $user = &#39;root&#39;;
    $pwd  = &#39;root&#39;;
    try {
        $pdo = new PDO($dsn, $user, $pwd);
        $sql = &#39;select * from user&#39;;
        $res = $pdo -> query($sql);
        echo &#39;errorCode 为:&#39;.$pdo -> errorCode().&#39;<br>&#39;;
        foreach ($res as $key => $value) {
            echo &#39;序号:&#39;.$value[&#39;id&#39;].&#39;; 姓名:&#39;.$value[&#39;name&#39;].&#39;; 年龄:&#39;.$value[&#39;age&#39;].&#39;; 性别:&#39;.$value[&#39;sex&#39;].&#39;<br>&#39;;
        }
    } catch (PDOException $e) {
        echo &#39;Connection failed: &#39; . $e->getMessage();
    }
?>

输出结果:

Bagaimana untuk mengendalikan ralat dalam PDO untuk pembelajaran pangkalan data PHP?

上述结果便是通过 errorCode() 方法获取错误代码。接下来我们看一下最后一种方法PDO::errorInfo() 方法。

<strong><span style="font-size: 20px;">PDO::errorInfo() </span></strong>方法

PDO::errorInfo() 方法与PDO::errorCode() 方法一样都是用于获取操作数据库句柄时所发生的错误信息。

不同的是errorInfo() 方法的返回值为一个数组,它包含了相关的错误信息。

接下来我们通过示例来看一下使用 PDO 中的 query 方法完成数据查询操作,并通过 errorInfo() 方法获取错误信息。

示例如下:

<?php
    $dsn  = &#39;mysql:dbname=test;host=127.0.0.1&#39;;
    $user = &#39;root&#39;;
    $pwd  = &#39;root&#39;;
    try {
        $pdo = new PDO($dsn, $user, $pwd);
        // $pdo -> setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        $sql = &#39;select * from userr&#39;;
        $res = $pdo -> query($sql);
        echo &#39;errorInfo 为:<br>&#39;;
        print_r($pdo -> errorInfo());
    } catch (PDOException $e) {
        echo &#39;Connection failed: &#39; . $e->getMessage();
    }
?>

上述示例中,我们查询了一个不存在的数据库,输出结果:

Bagaimana untuk mengendalikan ralat dalam PDO untuk pembelajaran pangkalan data PHP?

其中我们需要注意的是: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!

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
Artikel sebelumnya:Apakah maksud .= dalam php?Artikel seterusnya:Apakah maksud .= dalam php?