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

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

Oct 28, 2021 pm 04:54 PM
pdo 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.

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();
    }
?>
Salin selepas log masuk
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));
Salin selepas log masuk

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();
    }
?>
Salin selepas log masuk

输出结果:

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

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

<strong><span style="max-width:90%">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();
    }
?>
Salin selepas log masuk

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

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 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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 membawa beberapa ciri baharu, peningkatan keselamatan dan peningkatan prestasi dengan jumlah penamatan dan penyingkiran ciri yang sihat. Panduan ini menerangkan cara memasang PHP 8.4 atau naik taraf kepada PHP 8.4 pada Ubuntu, Debian, atau terbitan mereka

Tarikh dan Masa CakePHP Tarikh dan Masa CakePHP Sep 10, 2024 pm 05:27 PM

Untuk bekerja dengan tarikh dan masa dalam cakephp4, kami akan menggunakan kelas FrozenTime yang tersedia.

Muat naik Fail CakePHP Muat naik Fail CakePHP Sep 10, 2024 pm 05:27 PM

Untuk mengusahakan muat naik fail, kami akan menggunakan pembantu borang. Di sini, adalah contoh untuk muat naik fail.

Bincangkan CakePHP Bincangkan CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP ialah rangka kerja sumber terbuka untuk PHP. Ia bertujuan untuk menjadikan pembangunan, penggunaan dan penyelenggaraan aplikasi lebih mudah. CakePHP adalah berdasarkan seni bina seperti MVC yang berkuasa dan mudah difahami. Model, Pandangan dan Pengawal gu

Pengesah Mencipta CakePHP Pengesah Mencipta CakePHP Sep 10, 2024 pm 05:26 PM

Pengesah boleh dibuat dengan menambah dua baris berikut dalam pengawal.

Pembalakan CakePHP Pembalakan CakePHP Sep 10, 2024 pm 05:26 PM

Log masuk CakePHP adalah tugas yang sangat mudah. Anda hanya perlu menggunakan satu fungsi. Anda boleh log ralat, pengecualian, aktiviti pengguna, tindakan yang diambil oleh pengguna, untuk sebarang proses latar belakang seperti cronjob. Mengelog data dalam CakePHP adalah mudah. Fungsi log() disediakan

Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP Dec 20, 2024 am 11:31 AM

Kod Visual Studio, juga dikenali sebagai Kod VS, ialah editor kod sumber percuma — atau persekitaran pembangunan bersepadu (IDE) — tersedia untuk semua sistem pengendalian utama. Dengan koleksi sambungan yang besar untuk banyak bahasa pengaturcaraan, Kod VS boleh menjadi c

Panduan Ringkas CakePHP Panduan Ringkas CakePHP Sep 10, 2024 pm 05:27 PM

CakePHP ialah rangka kerja MVC sumber terbuka. Ia menjadikan pembangunan, penggunaan dan penyelenggaraan aplikasi lebih mudah. CakePHP mempunyai beberapa perpustakaan untuk mengurangkan beban tugas yang paling biasa.

See all articles