当前位置: 首页 > 面试题库 >

Golang Postgres错误常数?

栾弘新
2023-03-14
问题内容

我正在尝试通过以下方式使用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,这是一个结构。如果是这样,则可以使用其所有字段来检查错误的详细信息。

这是可以做到的:

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的,完整列表可在此处找到:错误和通知消息字段



 类似资料:
  • 目录表 错误 try..except 处理异常 引发异常 如何引发异常 try..finally 使用finally 概括 当你的程序中出现某些 异常的 状况的时候,异常就发生了。例如,当你想要读某个文件的时候,而那个文件不存在。或者在程序运行的时候,你不小心把它删除了。上述这些情况可以使用异常来处理。 假如你的程序中有一些无效的语句,会怎么样呢?Python会引发并告诉你那里有一个错误,从而处理

  • 错误 1 Error: Cannot find module 'gh-pages' at Function.Module._resolveFilename (module.js:489:15) at Function.Module._load (module.js:439:25) 上面的报错是:找不到 gh-pages 模块。 解决方法: npm i gh-pages

  • 我已经为发送电子邮件编写了自己的代码点火器模型。直到最近我开始出现这个错误,一切都很好: 致命错误:无法在/home/mysite/public\u html/subdir/application/libraries/phpmailer/class中重新声明类phpmailerException。phpmailer。php在线2319 我正在使用: 代码点火器2 PHP点火器5.1 我尝试了以下方

  • 忽略on_member_remove Traceback中的异常(最近一次调用为last):文件“C:\Users\Filbert\AppData\Local\Packages\PythonSoftwareFoundation.Python.3.8_qbz5n2kfra8p0\LocalCache\Local Packages\Python38\site Packages\discord\clie

  • 原因:异常[EclipseLink-6076](Eclipse持久性服务-2.5.0.v20130507-3faac2b):org。日食坚持不懈。例外。QueryException异常描述:对象比较只能用于OneToOneMappings。其他映射比较必须通过查询键或直接属性级比较来完成。映射:[org.eclipse.persistence.mappings.DirectToFieldMappi

  • 模板 安装完成后显示模板不存在 原因:数据库连接有错 解决办法: 删除app/Common/dataconfig.php 重新安装 或者 在配置文件里填写正确数据库连接信息