EntityFramework Удалить старые элементы dbupdateConcurrencyExceptionC#

Место общения программистов C#
Ответить
Anonymous
 EntityFramework Удалить старые элементы dbupdateConcurrencyException

Сообщение Anonymous »

у меня был следующий код, который удаляет элементы в таблице, которые были созданы более 30 дней назад. (DB является EntityFrameWorkCore 6 DBContext) < /p>
var expireBefore = DateTime.Now.AddDays(-30);
db.MyTable.RemoveRange(db.MyTable.Where(t => t.CreatedDate
Этот код выполнялся в нескольких местах одновременно, и иногда он бросил бы dbupdateconcurrencyexception < /p>

База данных Ожидалось, что операция повлияет на 1 строку, но фактически
затронута 0 строк (ы); Данные могли быть изменены или удалены с тех пор, как были загружены объекты
< /p>
< /blockquote>
Я считаю, что это произошло из -за условия гонки, где два места находят старые сущности, но только один может их удалить. Все еще иногда бросается. Почему транзакция здесь не предотвращает эту проблему? < /P>
var expireBefore = DateTime.Now.AddDays(-30);
var executionStrategy = db.Database.CreateExecutionStrategy();
await executionStrategy.ExecuteAsync(async () =>
{
await using var transaction = await db.Database.BeginTransactionAsync(IsolationLevel.Serializable);
db.MyTable.RemoveRange(db.MyTable.Where(t => t.CreatedDate

Подробнее здесь: https://stackoverflow.com/questions/794 ... yexception
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»