c# - Deleting a large number of records takes a VERY long time -
i have database table (running on sql server 2012 express) contains ~ 60,000 rows.
i using following code purge old rows:
//deleting cpu measurements older (oldestallowedtime) var allcpumeasurementsquery = curr in msdc.cpumeasurements curr.timestamp < oldestallowedtime select curr; foreach (var cpumeasurement in allcpumeasurementsquery) { msdc.cpumeasurements.remove(cpumeasurement); }
when number of deleted rows large (~90% or more of records in tables being deleted) operation takes exceptionally long. takes 30 minutes finish operation on relatively strong machine (intel i5 desktop).
does seem normal behavior?
any ideas can reduce operation's time?
thanks,
entity framework not @ handling bulk operations this. should use executestorecommand execute sql directly against data source in situations this.
var deleteold = "delete cpumeasurements curr.timestamp < {0}"; msdc.executestorecommand(deleteold, oldestallowedtime);
by doing don't need load entities memory (just delete them) , issue thousands of delete commands database.
Comments
Post a Comment