Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Postgres: sql, postgres, transaction

В чём разница между уровнями изоляции Read Committed и Repeatable Read в PostgreSQL?

Вопрос проверяет знание транзакций и аномалий изоляции, понимание, какие проблемы они решают и чем отличаются.

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

Read Committed гарантирует, что читаются только закоммиченные данные, но разные SELECT в одной транзакции могут видеть разное. Repeatable Read фиксирует снапшот в начале транзакции, и все запросы внутри её видят одну картину.

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

Read Committed:

  • каждый запрос видит только коммитнутые данные;

  • но если сделать два SELECT подряд, результаты могут отличаться (non-repeatable read).

Repeatable Read:

  • вся транзакция работает с единым снимком данных;

  • никакие новые коммиты других транзакций не видны;

  • предотвращает non-repeatable read, но фантомные чтения всё ещё возможны (хотя в Postgres почти нет).

-- транзакция 1
BEGIN;
SELECT balance FROM accounts WHERE id=1; -- 100
-- транзакция 2 параллельно обновляет balance=200 и коммитит
SELECT balance FROM accounts WHERE id=1; -- в Read Committed: уже 200, в Repeatable Read: всё ещё 100

Вывод: выбор уровня изоляции зависит от задачи: Read Committed быстрее, Repeatable Read безопаснее при аналитике.

  • Аватар

    Golang Guru

    Maxim Lukyanov

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

Уровень

  • Рейтинг:

    5

  • Сложность:

    7

Навыки

  • Postgres

    Postgres

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

#sql

#postgres

#transaction

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

  • Аватар

    Golang Guru

    Maxim Lukyanov

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