I am new to SQL Server and am not sure about how the locking mechanism works here. Please help
Issue: Need to delete close to 5 mil records in a table. A website pulls data from that table quite frequently.
My understanding is: delete would lock only the row hence this shouldn't affect the website. Is that right? Then, what would happen if the website is trying to pull the record that is being deleted? I know I sound very amateurish but I badly need to understand these basics.
Could one of the gurus please share a link where I can read up about the various kinds of locks in SQL Server as well
Best Answer
Sql Server's locks are described in good detail in the product documentation. A lock might or might not be escalated to page/table level, the behavior is documented, again, in Technet.
A fairly common tactic for deleting large amount of rows is to split up the delete in batches. Instead of deleting all the 5M rows at once like so,
rather try and delete data in, say, 100 * 50k row batches like so,
By splitting the delete in batches, you should lock way less data than with a all-encompassing single-pass delete. YMMV, depending on the selectivity and other activity in your table.
In addition, keep in mind that
delete
is logged and you might get a nasty surprise with your transaction log size.This article has nice an overview about how to batch delete data and mind the logs too.