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

Привет! Есть проблема с EF (.net framework, ef6) и race

conditions. Сценарий GET or CRETE -- приложение проверяет, существует ли запись для CutomerId = ... и если такой записи нет, то создает ее. Проблема, что параллельно приходят несколько запросов, и проверка для всех говорит, что записи нет, и несколько потоков ее создают -- получаются, дубли для одного и того же CustomerId создаются несколько записей. Можно ли как-то решить эту проблему на стороне приложения с помощью EF (не прибегая к stored procedure и Unique Constrain в БД)?

6 ответов

11 просмотров

транзакции?

Aanatoly-P. Автор вопроса
Сергей
транзакции?

и как? боюсь, что чтение _db.Any(...) не поможет, даже если его в тразнакцию завернуть. Или я чего-то не знаю?

Aanatoly P.
и как? боюсь, что чтение _db.Any(...) не поможет, ...

я не особо знаю как еф с транзакциями работает, но в теории можно селект и инсерт запихнуть в транзакцию TransactionScope

вообще нельзя сделать insert where not exists в еф? полюбому можно

Aanatoly-P. Автор вопроса
Сергей
я не особо знаю как еф с транзакциями работает, но...

мне понятно, как это сделать на стороне базы, но на стороне приложения я не знаю, не сталкивался с таким.

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

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

Типа вызывать GetParent и проверять на соответствие GetModuleHandle?
The Bird of Hermes
67
Do any of you guys have interesting projects one could join? I'm a Middle Full-Stack developer (JS/TS, React & Node)
Lev Shapiro
40
Есть сайт. Там была древняя версия эво. Стоял плагин, который каждый коммент в Jot делал отдельной страницей. После обновления все слетело, теперь старница открывается отдельн...
Artem
1
Всем привет! Кто нибудь парсил в ручную JSON без библиотек и фреймворков? Есть может ссылки на оптимальный алгоритмы работы с текстом и примеры таких парсеров?
Lem
27
$res = json_decode($наша строка из респонса); $res1 = array_map(fn($o) => $o->name, $res->breadcrumbs[0]->entities); Как такое будет на Хаскеле?.. В начале весь джейсон, в ко...
Хаскель Моисеевич Гопник
27
Добрый день. А shovel'ы можно как-то сконфигурировать в definitions.json? Пробовал что-то вроде: { "users": [ { "name": "agent", "password_hash": "RBCbTzQd...
Aleksey
1
Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
11
В чем сила брат, в NASM или FASM?
Isaac Kleiner
18
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
52
Карта сайта