Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimanakah saya boleh membezakan antara ralat generik dan keadaan khusus seperti ralat \"pangkalan data tidak wujud\" menggunakan pemacu Postgres?

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

Patricia Arquette
Patricia Arquetteasal
2024-11-03 02:50:03334semak imbas

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())
}

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

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!

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