我正在尝试通过以下方式使用postgres驱动程序(lib / pq)删除数据库:
db.Exec("DROP DATABASE dbName;")
但是我想根据收到的错误是奇怪的错误还是“数据库不存在”错误来做不同的条件。
我的问题是,是否有一个常量变量或可以用来检查返回的错误是否为“数据库不存在”错误消息的东西,还是我必须自己手动解析错误字符串?
我试图查看文档,但找不到“数据库不存在”的任何内容。但是我确实找到了此列表:https : //www.postgresql.org/docs/9.3/static/errcodes- appendix.html
也许它适合其他一些错误代码?另外,我不太确定通过Postgres驱动程序获取和比较错误代码的语义正确方法。我想我应该做这样的事情?:
if err.ErrorCode != "xxx"
谢谢。
所述lib/pq封装可以返回类型的错误*pq.Error,这是一个结构。如果是这样,则可以使用其所有字段来检查错误的详细信息。
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 具有以下字段:
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的,完整列表可在此处找到:错误和通知消息字段