go sql.Open 无法捕获错误

Liz8202 · 2024-02-23 10:05:22 · 731 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2024-02-23 10:05:22 的主题,其中的信息可能已经有所发展或是发生改变。

1、开发环境:go 1.19.1 windows/amd64

2、问题描述:执行sql.Open 无法捕获错误

3、相关代码

var db *sql.DB
var dbErr error

//创建数据建库连接:db为nil时创建
func CreateDbconnect() (*sql.DB,error){
    if db == nil {
        fmt.Println("into db == nil")

        //此处。在数据库信息不对的情况下,不会执行对应逻辑。导致继续执行db.Ping,然后返回一个没用的db。真正使用该dgb时报错
        if db, dbErr = sql.Open(driverName, dataSourceName); dbErr != nil {
            fmt.Println("db open error")
            return nil, dbErr
        }
        if dbErr = db.Ping(); dbErr != nil {
                fmt.Println("into db == ping")
                return nil, dbErr
        }
        fmt.Println("will out == ping")
    }
    fmt.Println("aiaiaiai")
    return db, nil
}

即这段代码始终不会执行if里边的逻辑

        //此处。在数据库信息不对的情况下,不会执行对应逻辑。导致继续执行db.Ping,然后返回一个没用的db。真正使用该dgb时报错
        if db, dbErr = sql.Open(driverName, dataSourceName); dbErr != nil {
            fmt.Println("db open error")
            return nil, dbErr
        }

请各位大佬帮看下此处问题出在哪儿


有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

731 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传