Организация объекта: удаление старых элементов приводит к DbupdateConcurrencyExceptionC#

Место общения программистов C#
Ответить
Anonymous
 Организация объекта: удаление старых элементов приводит к DbupdateConcurrencyException

Сообщение Anonymous »

у меня был следующий код, который удаляет элементы в таблице, которые были созданы более 30 дней назад (используя структуру предприятия Core 6 dbcontext ):
var expireBefore = DateTime.Now.AddDays(-30);
db.MyTable.RemoveRange(db.MyTable.Where(t => t.CreatedDate
Этот код выполнялся в нескольких местах одновременно, и иногда он бросил бы dbupdateconcurrencyException < /code>: < /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#»