Sobes.tech
Назад к вопросам
Junior
12

Существуют две транзакции. Сначала первая транзакция выполняет команду. Затем вторая транзакция выполняет команду. Далее первая транзакция продолжает выполняться. Какая последовательность приведет к взаимоблокировке? ```sql -- первая транзакция update accounts set balance = balance + 100 where id = ?; -- вторая транзакция update accounts set balance = balance - 50 where id = ?; update accounts set balance = balance + 200 where id = ?; ``` [phone]

Компании, где спрашивали
01.tech

Ответ от нейросети

sobes.tech AI

Взаимоблокировка (deadlock) возникает, если транзакции блокируют ресурсы в разном порядке и ждут друг друга.

В данном случае:

  • Первая транзакция обновляет баланс по id = A (предположим).
  • Вторая транзакция обновляет баланс по id = B, затем по id = C.
  • Первая транзакция продолжает выполнение и пытается обновить баланс по id = C.

Если первая транзакция заблокировала запись с id = A, а вторая транзакция заблокировала запись с id = C, и теперь первая пытается получить блокировку на id = C, а вторая — на id = A, то возникает взаимоблокировка.

Последовательность, приводящая к deadlock:

  1. Первая транзакция блокирует запись с id = A.
  2. Вторая транзакция блокирует запись с id = C.
  3. Первая транзакция пытается обновить запись с id = C (ждет освобождения).
  4. Вторая транзакция пытается обновить запись с id = A (ждет освобождения).

Обе транзакции ждут друг друга, что и вызывает deadlock.