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

Какой феномен может произойти phantom read или lost update в

такой транзакции





select count(*) from users where id=5;

insert into users (id, ...) values(5, ...)
То есть нужна гарантия, что между select и insert, другая транзакция не добавит юзера с id 5.

Вроде как count всегда вернёт 1 либо 0, то есть select for share / non repeatable read isolation должно хватит.
Но count при этом является аггрегативной функцией, которая не работает с 1 записью. Получается, что в таком случае поможет только serializable isolation level?

10 ответов

28 просмотров

В практически то какая задача? В вашем примере проще exception обработать

Ineffable- Автор вопроса
Konstantin Zaitsev
В практически то какая задача? В вашем примере про...

Да задача простая, создать пользователя. Можно и обработать, и не писать select даже. Но хорошее ли это решение?

Ineffable
Да задача простая, создать пользователя. Можно и о...

Хорошее добавить последовательность и забыть

Ineffable- Автор вопроса
Ineffable
Да задача простая, создать пользователя. Можно и о...

GENERATED ALWAYS AS IDENTITY для id В insert добавить returning и получить значение.

Ineffable- Автор вопроса
Konstantin Zaitsev
GENERATED ALWAYS AS IDENTITY для id В insert доба...

В моем случае я получаю из вне id с другой бд, поэтому здесь генерация не нужна

Ineffable
В моем случае я получаю из вне id с другой бд, поэ...

у вас в users поле id - это primary key должно быть, сделайте insert on conflict do nothing или в чем тут проблема?

Ineffable- Автор вопроса
Nikolay Gladkov
у вас в users поле id - это primary key должно быт...

Мне нужна информация, о том, получилось ли добавить или нет, воопщем просто обработаю тогда ошибку

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

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

Мужики и девушки, привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных...
Kraszx
14
Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
А вот это что за конструкция? Вернее, она тут нафига?
Serjone
10
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
Мужики. привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных элементов...
Kraszx
2
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
я так понимаю, я так подозреваю, что создание такого плагина для человека, кто умеет писать плагины для делфи потребует минут 5-10 времени. но это мое подозрение. хотелось бы ...
Kraszx
7
Всем привет! Кто пользуется DevExpress, подскажите пожалуйста, реализован ли в TcxGrid в новых версиях поиск по датам как в Экселе (ну т.е. не просто список чекбоксов со значе...
A Z
4
Карта сайта