在使用 database/sql 的 Go 程序中,当我对正在使用的 Postgres 数据库进行 Close 时,是否会关闭任何未关闭的准备好的查询?

我已经把它简化为一个非常简单的例子,它不需要 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

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

defer stmt.Close()

或类似。

关于postgresql - 如果 Go sql.DB 已关闭,是否会关闭任何未关闭的准备查询?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/52174361/

10-16 16:44