我正在使用这个库来批量执行批量删除,如下所示:
while (castedEndedItems.Any())
{
var subList = castedEndedItems.Take(4000).ToList();
DBRetry.Do(() => EFBatchOperation.For(ctx, ctx.SearchedUserItems).Where(r => subList.Any(a => a == r.ItemID)).Delete(), TimeSpan.FromSeconds(2));
castedEndedItems.RemoveRange(0, subList.Count);
Console.WriteLine("Completed a batch of ended items");
}
如您所见,我一次删除了一批 4000 个项目,并将它们作为参数传递给查询...
我正在使用这个库来执行批量删除:
https://github.com/MikaelEliasson/EntityFramework.Utilities
然而,这样的性能绝对是可怕的......我测试了几次应用程序并删除了 80000 条记录,例如它需要 40 分钟!?
我应该注意,我删除的那个参数 (ItemID) 是 varchar(400) 类型的,并且出于性能原因对其进行了索引....
是否有任何其他库我可以使用或调整此查询以使其更快地工作,因为目前性能绝对糟糕..:/