登录
首页 >  Golang >  Go问答

将错误转换为go-sqlite3.Error是不可能的

来源:stackoverflow

时间:2024-03-06 22:24:19 282浏览 收藏

欢迎各位小伙伴来到golang学习网,相聚于此都是缘哈哈哈!今天我给大家带来《将错误转换为go-sqlite3.Error是不可能的》,这篇文章主要讲到等等知识,如果你对Golang相关的知识非常感兴趣或者正在自学,都可以关注我,我会持续更新相关文章!当然,有什么建议也欢迎在评论留言提出!一起学习!

问题内容

我试图将 go 中的错误转换为 go-sqlite3.error,但总是失败。 上图代表了我的调试窗口的快照,它显示错误的类型为 go-sqlite3.error

我正在使用下面的代码进行类型转换。

import (
    "github.com/mattn/go-sqlite3"
)

if err != nil {
    if sqlite3Err, ok := err.(*sqlite3.Error); ok {
        if sqlite3Err.Code == sqlite3.ErrConstraint && sqlite3Err.ExtendedCode == 1555 {
            // SQLITE3 ERROR 1555 : PRIMARY KEY CONSTRAINT ERROR
            return errors.New("Log Error")
        }
    }

解决方案


尝试以下示例。 err.(*sqlite3.error) 更改为 err.(sqlite3.error)

if sqlite3Err, ok := err.(sqlite3.Error); ok {
    if sqlite3Err.Code == sqlite3.ErrConstraint &&
        sqlite3Err.ExtendedCode == 1555 {
        // logic 
    }
}

本篇关于《将错误转换为go-sqlite3.Error是不可能的》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>