Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Postgres: row locking, concurrency, transaction

Что такое SELECT FOR UPDATE и как он помогает в решении проблем параллельного доступа?

Вопрос проверяет знание механизма блокировки строк при конкурентном доступе к данным.

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

SELECT FOR UPDATE блокирует выбранные строки от изменений другими транзакциями. Это полезно при реализации очередей задач или других сценариев, где важно гарантировать эксклюзивную работу с данными.

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

SELECT ... FOR UPDATE — это способ получить эксклюзивную блокировку на строки, участвующие в выборке. До завершения транзакции эти строки не могут быть изменены другими транзакциями.

Как работает:

  • Строка блокируется сразу после выборки

  • Другие транзакции, которые попытаются заблокировать ту же строку — будут ждать или получат ошибку

Пример:

BEGIN;
SELECT * FROM email_tasks WHERE is_sent = false ORDER BY created_at LIMIT 1 FOR UPDATE;
-- Отправка письма
UPDATE email_tasks SET is_sent = true WHERE id = @id;
COMMIT;

В C# через Dapper или EF Core:

using var tx = db.Database.BeginTransaction();
var task = db.EmailTasks
    .FromSqlRaw("SELECT * FROM email_tasks WHERE is_sent = false FOR UPDATE")
    .FirstOrDefault();
// отправка
task.IsSent = true;
db.SaveChanges();
tx.Commit();

Применение:

  • Очереди задач

  • Распределённая обработка писем, уведомлений

  • Защита от конкурентных изменений

Когда использовать:

  • При высокой конкуренции и необходимости гарантировать, что один объект обрабатывается только одним процессом

  • Аватар

    Golang Guru

    Maxim Lukyanov

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

Уровень

  • Рейтинг:

    1

  • Сложность:

    8

Навыки

  • Postgres

    Postgres

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

#row locking

#concurrency

#transaction

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

  • Аватар

    Golang Guru

    Maxim Lukyanov

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