为了账号安全,请及时绑定邮箱和手机立即绑定

无法连接到数据库:数据库已关闭

无法连接到数据库:数据库已关闭

Go
凤凰求蛊 2023-07-10 16:25:43
我有以下项目结构:-main.go-db--dbinit.go我dbinit.go有以下代码:package dbimport (    "database/sql"    _ "github.com/go-sql-driver/mysql")var Db *sql.DBvar err errorfunc init() {    Db, err = sql.Open("mysql", "myDBCreds")    defer Db.Close()}我有main.go:package main import (    db "./db")func main() {    defer db.Db.Close()        sqlStatement := `INSERT INTO table (field1, field2)            VALUES ($1, $2)        `        _, err := db.Db.Exec(sqlStatement, param1, param2)        if err != nil {            panic(err)        }但main.go不断抛出错误:sql:数据库已关闭我究竟做错了什么?
查看完整描述

1 回答

?
有只小跳蛙

TA贡献1824条经验 获得超8个赞

来自之前提出的问题

返回的数据库对于多个 goroutine 并发使用是安全的,并维护自己的空闲连接池。因此,Open 函数应该只调用一次。很少需要关闭数据库。

又说,不要关闭它。


查看完整回答
反对 回复 2023-07-10
  • 1 回答
  • 0 关注
  • 92 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信