A multiuser environment must have the means to prevent concurrent transactions from interfering with each other. SQL Server employs a fast, sophisticated, automatic, and transparent locking scheme that arbitrates user requests. The process of obtaining a lock is exceptionally fast—a matter of microseconds—because lock information is stored in a memory-resident table. SQL Server employs multiple levels of locking (depending on the degree of exclusion required) and uses the least restrictive lock needed to protect data during a given operation.
SQL Server automatically acquires the necessary locks whenever a SQL statement is executed. SQL Server uses:
Within SQL Server, the efficient use of automatic locking prevents destructive interference from concurrent transactions. By default, the changes made by the SQL statements only become visible to other transactions after those changes are committed.