Search code examples
c#linq-to-sqldelete-row

Linq to Sql: How to quickly clear a table


To delete all the rows in a table, I am currently doing the following:

context.Entities.DeleteAllOnSubmit(context.Entities);
context.SubmitChanges();

However, this seems to be taking ages. Is there a faster way?


Solution

  • You could do a normal SQL truncate or delete command, using the DataContext.ExecuteCommand method:

    context.ExecuteCommand("DELETE FROM Entity");
    

    Or

    context.ExecuteCommand("TRUNCATE TABLE Entity");
    

    The way you are deleting is taking long because Linq to SQL generates a DELETE statement for each entity, there are other type-safe approaches to do batch deletes/updates, check the following articles: