В программе Go, использующей database/sql
, будут ли закрыты подготовленные запросы, когда я 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 = $1 LIMIT 1
`)
if err != nil {
return Info{}
}
var res Info
_ = stmt.QueryRow(id).Scan(&res.ID, &res.Name)
return res
}