登录
首页 >  Golang >  Go问答

如果 Go sql.DB 关闭,是否会关闭任何未关闭的准备好的查询?

来源:stackoverflow

时间:2024-04-23 14:15:36 201浏览 收藏

今日不肯埋头,明日何以抬头!每日一句努力自己的话哈哈~哈喽,今天我将给大家带来一篇《如果 Go sql.DB 关闭,是否会关闭任何未关闭的准备好的查询?》,主要内容是讲解等等,感兴趣的朋友可以收藏或者有更好的建议在评论提出,我都会认真看的!大家一起进步,一起学习!

问题内容

在使用 database/sql 的 go 程序中,当我 clos​​e 我正在使用的 postgres 数据库时,是否会关闭任何未关闭的准备好的查询?

我已将其简化为一个非常简单的示例,不需要 prepare 但仍然显示问题(我相信我可以将查询字符串传递给 queryrow 并获得隐式 prepare,但将其显式保留在此处,以便我可以问我的问题):

import (
    "database/sql"
)

// Store struct is the postgres
type Store struct {
    pq *sql.DB
}

type Info struct {
    ID      string `json:"id"`
    Name    string `json:"name"`
}

func (s *Store) GetInfo(id string) Info {
    defer s.pq.Close()
    stmt, err := s.pq.Prepare(`
            SELECT id, name 
            FROM info 
            WHERE id = $1 LIMIT 1
            `)
    if err != nil {
        return Info{}
    }
    var res Info
    _ = stmt.QueryRow(id).Scan(&res.ID, &res.Name)
    return res
}

解决方案


从技术上讲,database/sql definitely expects you to close your own prepared statements 在 db 或 dc 关闭时不会为您执行此操作。此外,我认为当你的程序退出时,服务器可能会清理后端内存,但 postgresql 也不会清理它......

https://github.com/lib/pq/issues/446

如果您获得隐式“准备”,那么 database/sql 将为您处理清理工作,但如果您一遍又一遍地运行这些查询,效率会降低,因此我强烈建议您使用以下命令自行清理:

defer stmt.Close()

或类似的。

今天关于《如果 Go sql.DB 关闭,是否会关闭任何未关闭的准备好的查询?》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

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