db.Exec(...) 返回的错误是否有代码?
来源:Golang技术栈
时间:2023-04-12 21:35:23 278浏览 收藏
亲爱的编程学习爱好者,如果你点开了这篇文章,说明你对《db.Exec(...) 返回的错误是否有代码?》很感兴趣。本篇文章就来给大家详细解析一下,主要介绍一下golang,希望所有认真读完的童鞋们,都有实质性的提高。
问题内容
我正在尝试通过执行以下操作使用 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
为
struct 的错误。如果是这样,您可以使用其所有字段来检查错误的详细信息。
这是可以做到的:
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 特定的,完整列表可以在这里找到:[错误和通知消息字段](https://www.postgresql.org/docs/current/static/protocol- error-fields.html)
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。
-
439 收藏
-
262 收藏
-
193 收藏
-
188 收藏
-
500 收藏
-
139 收藏
-
204 收藏
-
325 收藏
-
477 收藏
-
486 收藏
-
439 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习