如果 Go sql.DB 关闭,是否关闭任何未关闭的准备查询?
If a Go sql.DB is closed, do any unclosed prepared queries get closed?
在使用 database/sql
的 Go 程序中,当我 Close
我正在使用的 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 = 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()
或类似。
在使用 database/sql
的 Go 程序中,当我 Close
我正在使用的 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 = 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()
或类似。