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

问题描述 投票:4回答:1

在使用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
}
postgresql go resource-leak
1个回答
2
投票

从技术上讲,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()

或类似的。

© www.soinside.com 2019 - 2024. All rights reserved.