Bagaimanakah saya boleh membezakan antara ralat generik dan keadaan khusus seperti ralat \'pangkalan data tidak wujud\' menggunakan pemacu Postgres?

Patricia Arquette
Lepaskan: 2024-11-03 02:50:03
asal
342 orang telah melayarinya

How can I differentiate between generic errors and specific conditions like

Mendapatkan Kod Ralat daripada Operasi Pangkalan Data

Apabila melaksanakan pertanyaan menggunakan pemacu Postgres (lib/pq), kadangkala perlu membezakan antara ralat generik dan keadaan khusus seperti ralat "pangkalan data tidak wujud". Untuk memudahkan ini, pemandu Postgres menyediakan pendekatan berstruktur untuk memeriksa butiran ralat.

Mengakses Kod Ralat

Ralat yang dikembalikan oleh db.Exec(...) adalah daripada taip *pq.Error, struct yang mengandungi pelbagai medan yang menerangkan ralat. Untuk mengakses medan ini, gunakan sintaks berikut:

if err, ok := err.(*pq.Error); ok {
    // Inspect error fields, such as:
    fmt.Println("Error code:", err.Code.Name())
}
Salin selepas log masuk

Mengenalpasti Ralat "Pangkalan Data Tidak Wujud"

Malangnya, tiada kod ralat khusus untuk "pangkalan data tidak wujud" ralat. Sebaliknya, ia berada di bawah ralat "28003: pangkalan data tidak wujud" yang lebih umum. Untuk menyemak keadaan ini, gunakan kod berikut:

if err, ok := err.(*pq.Error); ok {
    if err.Code.Name() == "28003" {
        // Database does not exist
    }
}
Salin selepas log masuk

Medan Tambahan

Selain kod ralat, struct *pq.Error menyediakan lain yang berguna medan, termasuk:

  • Mesej: Mesej ralat yang boleh dibaca manusia.
  • Keterukan: Keterukan ralat, bermula daripada "NOTIS" kepada "FATAL."
  • Butiran: Butiran tambahan tentang ralat.
  • Petunjuk: Cadangan tentang cara menyelesaikan ralat .
  • Kedudukan: Kedudukan dalam pernyataan SQL di mana ralat berlaku.

Dengan menggunakan medan ini, pembangun boleh memperoleh pemahaman yang lebih mendalam tentang ralat yang dihadapi semasa operasi pangkalan data, membolehkan pengendalian ralat dan penyahpepijatan yang lebih termaklum.

Atas ialah kandungan terperinci Bagaimanakah saya boleh membezakan antara ralat generik dan keadaan khusus seperti ralat \'pangkalan data tidak wujud\' menggunakan pemacu Postgres?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!