172 похожих чатов

Postgresql 10 Есть простой запрос UPDATE users SET name = "John" WHERE

id in ({many_ids});

При паралельных процессах, которые пытаются обновить одинаковые айдишки натыкаются на ошибку о deadlock.

По хорошему как решать такие проблемы?

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

3 ответов

7 просмотров

А проблема-то в чём (ну deadlock и deadlock — бывает)?

Добавь order by id. База сначала выбирает, потом лочит. Для разных запросов может в разном порядке и будет дедлок. В определенном порядке просто ждать будет

Только order by на select for update сделайте, потом update

Похожие вопросы

Обсуждают сегодня

Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
А чем вам питонисты не угодили?😂
.
79
Можно ли загрузить скрипт py в бота чтобы он работал по нему? как это сделать?
huskadam #RCC Фанат? @hitlerpvp
13
Всем здравствуйте! Я хотел узнать сколько стоит средняя месячная зарплата у Electron js разработчиков? Мне очень это важно и нужно, плиз помогите узнать эту инфу! Для Джунио...
U.K.
10
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
77
А дин типизация это хорошо или плохо?
Alexey
12
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Исходники плюс документация? Вы гоните)) демок хватит всем
zamtmn
11
Карта сайта