SQL Server, Locks object

Applies to: SQL Server

The SQLServer:Locks object in Microsoft SQL Server provides information about SQL Server locks on individual resource types. Locks are held on SQL Server resources, such as rows read or modified during a transaction, to prevent concurrent use of resources by different transactions. For example, if an exclusive (X) lock is held on a row within a table by a transaction, no other transaction can modify that row until the lock is released. Minimizing locks increases concurrency, which can improve performance. Multiple instances of the Locks object can be monitored at the same time, with each instance representing a lock on a resource type.

This table describes the SQL Server Locks counters.

SQL Server Locks counters Description
Average Wait Time (ms) Average amount of wait time (in milliseconds) for each lock request that resulted in a wait.
Average Wait Time Base For internal use only.
Lock Requests/sec Number of new locks and lock conversions per second requested from the lock manager.
Lock Timeouts (timeout > 0)/sec Number of lock requests per second that timed out, but excluding requests for NOWAIT locks.
Lock Timeouts/sec Number of lock requests per second that timed out, including requests for NOWAIT locks.
Lock Wait Time (ms) Total wait time (in milliseconds) for locks in the last second.
Lock Waits/sec Number of lock requests per second that required the caller to wait.
Number of Deadlocks/sec Number of lock requests per second that resulted in a deadlock.

SQL Server can lock these resources.

Item Description
_Total Information for all locks.
AllocUnit A lock on an allocation unit.
Application A lock on an application-specified resource.
Database A lock on a database, including all objects in the database.
Extent A lock on a contiguous group of 8 pages.
File A lock on a database file.
Heap/B-tree Heap or B-tree. A lock on a heap of data pages, or on the B-tree structure of an index.
Key A lock on a row in an index.
Metadata A lock on a piece of catalog information, also called metadata.
Object A lock on table, stored procedure, view, etc, including all data and indexes. The object can be anything that has an entry in sys.all_objects.
OIB Lock resource for online index build locks, specifically for a online index build LOB tracking table.
Page A lock on an 8-kilobyte (KB) page in a database.
RID Row ID. A lock on a single row in a heap.
RowGroup Lock resource for a columnstore index rowgroup.
Xact Lock resource for a transactions.

Note

Documentation uses the term B-tree generally in reference to indexes. In rowstore indexes, the Database Engine implements a B+ tree. This does not apply to columnstore indexes or indexes on memory-optimized tables. For more information, see the SQL Server and Azure SQL index architecture and design guide.

Example

You begin to explore the query performance counters in this object using this T-SQL query on the sys.dm_os_performance_counters dynamic management view:

SELECT * FROM sys.dm_os_performance_counters
WHERE object_name LIKE '%Locks%';