database - db.Exec(...) 返回的错误是否有代码?

标签 database postgresql go

我正在尝试通过以下操作删除使用 postgres 驱动程序 (lib/pq) 的数据库:

db.Exec("DROP DATABASE dbName;")

但我想根据收到的错误是奇怪的还是“数据库不存在”错误来做一个不同的条件。

是否有常量变量或其他东西可以用来检查返回的错误是否是“数据库不存在”错误消息,或者我是否必须自己手动解析错误字符串?

我试图查看文档,但找不到“数据库不存在”的任何内容。但是我确实找到了this list .

也许它适合其他一些错误代码?此外,我不太确定通过 Postgres 驱动程序获取和比较错误代码的语义正确方式。我想我应该做这样的事情:

if err.ErrorCode != "xxx"

最佳答案

lib/pq包可能会返回 *pq.Error 类型的错误,这是一个结构。如果是,您可以使用其所有字段来检查错误的详细信息。

这是可以做到的:

if err, ok := err.(*pq.Error); ok {
    // Here err is of type *pq.Error, you may inspect all its fields, e.g.:
    fmt.Println("pq error:", err.Code.Name())
}

pq.Error 有以下字段:

type Error struct {
    Severity         string
    Code             ErrorCode
    Message          string
    Detail           string
    Hint             string
    Position         string
    InternalPosition string
    InternalQuery    string
    Where            string
    Schema           string
    Table            string
    Column           string
    DataTypeName     string
    Constraint       string
    File             string
    Line             string
    Routine          string
}

这些字段的含义和可能的值是特定于 Postres 的,完整的列表可以在这里找到:Error and Notice Message Fields

关于database - db.Exec(...) 返回的错误是否有代码?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37560534/

相关文章:

django - 南迁: DatabaseOperations has not attribute 'shorten_name'

mysql - ASCII 字符的 SQL 查询

database - django uml 数据库

java - MySQL 选择从 300 毫秒跳到 20 秒额外 5 行

go - 如何将数据库中的点坐标转换为GoLang中的点结构

go - 从核心函数获取未知类型的nil值

string - 如何将通配符 * 集成到数学验证路由中

php - 我将如何插入影响多个表的值?

postgresql - 在postgis中按中心点、半径、内角和方位角绘制扇区

php - 生成的 Postgresql 进程可以由 spawner PHP 脚本控制吗?