Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Golang: go, db, database, rows, pool

Что произойдёт, если забыть вызвать rows.Close() при работе с database/sql?

Проверяет знание работы с ресурсами и connection pool в Go.

Короткий ответ

Если не закрыть rows, соединение может не вернуться в пул. Под нагрузкой это приводит к исчерпанию соединений и “подвисанию” запросов.

Длинный ответ

database/sql использует пул соединений. rows держит связь с конкретным соединением, пока:

  • вы не дочитали результаты до конца, или

  • не вызвали rows.Close().

Если забыть Close:

  1. Соединение удерживается и не возвращается в пул.

  2. Под нагрузкой пул заканчивается (MaxOpenConns), новые запросы ждут.

  3. Возникают таймауты и деградация сервиса.

Дополнительно важно:

  • проверять rows.Err() после цикла;

  • закрывать rows, даже если вышли из цикла раньше (например, нашли первый элемент).

Вывод: rows.Close() — это не “опционально”, а обязательное освобождение ресурсов пула.

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.

Уровень

  • Рейтинг:

    4

  • Сложность:

    6

Навыки

  • Golang

    Golang

  • Postgres

    Postgres

Ключевые слова

#go

#db

#database

#rows

#pool

Подпишись на Golang Developer в телеграм

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.