Rumah >pembangunan bahagian belakang >Golang >Bagaimanakah saya boleh membezakan antara ralat generik dan keadaan khusus seperti ralat \'pangkalan data tidak wujud\' menggunakan pemacu Postgres?
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:
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!