dtg78700 2018-10-23 04:48
浏览 10
已采纳

将本地结果分配给外部范围

I have this block of code. The problem is in the func, I am trying to assign to the db var in outer scope, but it ends up being declared as a local variable.

var db *sqlx.DB

func GetDatabaseConnection() *sqlx.DB {

    if db == nil {

        db, err := sqlx.Connect("postgres", "user=foo dbname=bar sslmode=disable")
        if err != nil {
            log.Fatalln(err)
        }

    }

    return db
}

my question is, regarding this line:

db, err := sqlx.Connect(...)

how can I assign db to the outer scope, and not declare it as a local varible?

  • 写回答

1条回答 默认 最新

  • duanmen8491 2018-10-23 04:54
    关注
    var db *sqlx.DB
    
    func GetDatabaseConnection() *sqlx.DB {
    
        if db == nil {
            var err error # ADD THIS LINE, AND DO = INSTEAD OF := ON NEXT LINE
            db, err = sqlx.Connect("postgres", "user=foo dbname=bar sslmode=disable")
            if err != nil {
                log.Fatalln(err)
            }
    
        }
    
        return db
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

    报告相同问题?

    悬赏问题

    • ¥15 关于网上一个easyx制作的见缝插针小游戏(c++)
    • ¥15 开地址法双散列函数处理碰撞
    • ¥15 想问一下这个是什么情况 虚拟机Linux打不开了
    • ¥15 联通光猫掉注册了怎么重新注册上去
    • ¥15 关于unity开发steamvr程序遇到的问题
    • ¥60 求tc downloader的下载方式
    • ¥15 华为 快捷方式 手电筒 接口
    • ¥15 Qt6.5支不支持Android13开发啊
    • ¥20 网络只能跑一半,应该如何设置
    • ¥20 Python调用百度开发者平台人脸识别接口