gpt4 book ai didi

go - 在包之间共享 SQL 连接的惯用方法是什么?

转载 作者:IT王子 更新时间:2023-10-29 02:06:04 26 4
gpt4 key购买 nike

我通常在主包中声明一个公共(public)的Db变量

package main

var Db *sql.DB

func main() {
var err error
Db, err = sql.Open("sqlite3", BARS_FILE)
if err != nil {
log.Fatal(err)
}

defer Db.Close()
// passing Db as a parameter to other functions in other packages (database
// repositories)

}

有更好的方法吗?

最佳答案

根据 http://golang.org/pkg/database/sql/#DB以这种方式使用 sql.DB 是安全的:

DB is a database handle. It's safe for concurrent use by multiple goroutines.

恕我直言,可以那样使用它。也许稍后,当这个变量成为瓶颈时,您可以创建更多句柄。如果很多 gouroutines 开始使用它,就会发生这种情况。但在必要之前不要优化。

关于go - 在包之间共享 SQL 连接的惯用方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23017688/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com