Active Lock Requests (vlock.sql)
What This Script Does
Section titled “What This Script Does”This script provides a simple, direct view of all active lock requests in the database. It shows sessions that are currently waiting to acquire locks, which is essential for identifying lock contention and blocking situations in real-time.
Script
Section titled “Script”set lines 132select * from v$lockwhere request > 0/-- Run the script in SQL*Plus or SQLcl@vlock.sql
-- No parameters required-- Shows current lock requests at time of executionRequired Privileges
Section titled “Required Privileges”- SELECT on V$LOCK
- Generally available to most database users
Sample Output
Section titled “Sample Output”    ADDR     KADDR           SID TY        ID1        ID2      LMODE    REQUEST      CTIME      BLOCK-------- -------- ---------- -- ---------- ---------- ---------- ---------- ---------- ----------70000123 70000456        145 TX      65537      12345          0          6        125          070000234 70000567        234 TX      65538      67890          0          4         89          070000345 70000678        156 TM      98765          0          0          3         45          070000456 70000789        278 DL      11111      22222          0          4         12          0Key Output Columns
Section titled “Key Output Columns”- ADDR: Memory address of lock structure
- KADDR: Address of lock state object
- SID: Session ID requesting the lock
- TY: Lock type (TX, TM, DL, etc.)
- ID1/ID2: Lock identifiers (object-specific)
- LMODE: Lock mode currently held (0 = none)
- REQUEST: Lock mode being requested
- CTIME: Time since request started (centiseconds)
- BLOCK: Whether this session is blocking others (0/1)
Understanding Lock Types
Section titled “Understanding Lock Types”Common Lock Types
Section titled “Common Lock Types”- TX: Transaction lock (row-level locks)
- TM: Table lock (DML table locks)
- DL: Direct loader lock
- UL: User-defined lock
- RT: Redo thread lock
- TS: Tablespace lock
Lock Modes
Section titled “Lock Modes”- 0: None
- 1: Null (NL)
- 2: Row Share (RS) / Sub Share (SS)
- 3: Row Exclusive (RX) / Sub Exclusive (SX)
- 4: Share (S)
- 5: Share Row Exclusive (SRX) / Share Sub Exclusive (SSX)
- 6: Exclusive (X)
Performance Analysis
Section titled “Performance Analysis”Identifying Critical Waits
Section titled “Identifying Critical Waits”- High CTIME values: Long-running lock waits
- REQUEST = 6 (Exclusive): High-impact lock requests
- Multiple sessions same ID1/ID2: Lock contention hotspot
- TX locks: Row-level contention
Wait Time Analysis
Section titled “Wait Time Analysis”- CTIME < 100 (< 1 second): Normal brief waits
- CTIME 100-1000 (1-10 seconds): Concerning waits
- CTIME > 1000 (> 10 seconds): Critical blocking
Common Use Cases
Section titled “Common Use Cases”Immediate Troubleshooting
Section titled “Immediate Troubleshooting”-- Quick check for lock waits@vlock.sql-- Look for high CTIME valuesPerformance Investigation
Section titled “Performance Investigation”-- During application slowdowns@vlock.sql-- Identify lock types and wait patternsReal-time Monitoring
Section titled “Real-time Monitoring”-- Continuous monitoring during operations@vlock.sql-- Track lock request patternsTroubleshooting Lock Waits
Section titled “Troubleshooting Lock Waits”Identify Blocking Sessions
Section titled “Identify Blocking Sessions”-- Find who is blocking these requestsSELECT l1.sid waiting_session,       l2.sid blocking_session,       l1.type lock_type,       l1.id1, l1.id2,       l1.ctime wait_timeFROM v$lock l1, v$lock l2WHERE l1.request > 0AND l2.block = 1AND l1.id1 = l2.id1AND l1.id2 = l2.id2AND l1.type = l2.type;Get Session Details
Section titled “Get Session Details”-- Details about waiting sessionsSELECT s.sid, s.username, s.program, s.machine,       s.last_call_et, s.status, s.sql_idFROM v$session s, v$lock lWHERE s.sid = l.sidAND l.request > 0;Find Locked Objects
Section titled “Find Locked Objects”-- What objects are being locked (for TM locks)SELECT o.owner, o.object_name, o.object_type,       l.sid, l.type, l.lmode, l.requestFROM v$lock l, dba_objects oWHERE l.type = 'TM'AND l.id1 = o.object_idAND l.request > 0;Advanced Analysis
Section titled “Advanced Analysis”Lock Conversion Waits
Section titled “Lock Conversion Waits”-- Sessions converting lock modesSELECT sid, type, id1, id2, lmode, request,       CASE         WHEN lmode > 0 AND request > lmode THEN 'UPGRADE'         WHEN lmode > 0 AND request < lmode THEN 'DOWNGRADE'         WHEN lmode = 0 THEN 'INITIAL'       END conversion_typeFROM v$lockWHERE request > 0;Lock Wait Chains
Section titled “Lock Wait Chains”-- Find blocking chainsWITH lock_chain AS (  SELECT l1.sid waiter, l2.sid blocker,         l1.type, l1.id1, l1.id2, l1.ctime  FROM v$lock l1, v$lock l2  WHERE l1.request > 0  AND l2.block = 1  AND l1.id1 = l2.id1  AND l1.id2 = l2.id2  AND l1.type = l2.type)SELECT waiter, blocker, type, ctime,       CONNECT_BY_ISLEAF is_leaf,       LEVEL chain_levelFROM lock_chainCONNECT BY PRIOR waiter = blockerSTART WITH blocker NOT IN (SELECT waiter FROM lock_chain);Historical Lock Analysis
Section titled “Historical Lock Analysis”-- Check for recurring lock patternsSELECT type, COUNT(*) wait_count,       AVG(ctime) avg_wait_time,       MAX(ctime) max_wait_timeFROM v$lockWHERE request > 0GROUP BY typeORDER BY wait_count DESC;Related Scripts
Section titled “Related Scripts”- Locked Objects Detail - Comprehensive locked object analysis
- Blocking Locks - Blocking session identification
- Session Activity - Active session analysis
- Lock Statistics - System-wide lock statistics