共用方式為


Lock:Acquired 事件類別

適用於: SQL Server 2016 (13.x) 及以後版本 Azure SQL Database AzureSQL Managed InstanceSQL database in Microsoft Fabric

Lock:Acquired 事件類別表示已達成對資源(如資料頁)的鎖定。

Lock:Acquired 和 Lock:Released 事件類別可用來監視物件何時鎖定、所擷取的鎖定類型,以及保留鎖定的時間長度。 鎖長期保留可能會引發爭用問題,應進行調查。 例如,應用程式可以取得數據表中數據列的鎖定,然後等候用戶輸入。 由於使用者輸入可能需要很長的時間才會發生,因此鎖定可能會封鎖其他使用者。 在此實例中,應用程式應該重新設計,只有在需要時才提出鎖定要求,而且在取得鎖定時不需要用戶輸入。

Lock:Acquired 事件類別數據行

數據行名稱 資料類型 描述 資料行識別碼 可篩選
ApplicationName nvarchar 建立 Microsoft SQL Server 實例之連線的用戶端應用程式名稱。 此資料行會填入應用程式所傳遞的值,而不是顯示的程式名稱。 10 Yes
BigintData1 bigint 如果已分割鎖定資源,則為分割區標識符。 52 Yes
BinaryData image 鎖定資源標識碼。 2 Yes
ClientProcessID int 主計算機指派給執行用戶端應用程式的進程標識碼。 如果用戶端提供客戶端進程識別碼,就會填入此資料行。 9 Yes
DatabaseID int 取得鎖定的資料庫標識碼。 如果在追蹤中擷取到 ServerName 資料行且伺服器可用,SQL Server Profiler 便會顯示資料庫的名稱。 請使用 DB_ID 函數判斷資料庫的值。 3 Yes
期間 bigint 從取得鎖到解鎖或取消之間的時間(以微秒計)。 13 Yes
EndTime datetime 事件結束的時間。 15 Yes
EventClass int 事件類型 = 24。 27 No
EventSequence int 要求內指定事件的順序。 51 No
GroupID int SQL 追蹤事件引發之工作負載群組的標識碼。 66 Yes
HostName nvarchar 用戶端執行所在的計算機名稱。 如果用戶端提供主機名,則會填入此數據行。 若要判斷主機名稱,請使用 HOST_NAME 函數。 8 Yes
IntegerData2 int 僅供參考之用。 不支援。 我們無法保證未來的相容性。 55 Yes
IsSystem int 指出事件發生在系統進程或用戶進程上。 1 = 系統,0 = 使用者。 60 Yes
LoginName nvarchar 使用者登入的名稱(SQL Server 安全性登入或網域\用戶名稱形式的 Windows 登入認證)。 11 Yes
LoginSid image 已登入使用者的安全性識別碼(SID)。 您可以在目錄視圖中找到 sys.server_principals 此資訊。 每一個 SID 對於伺服器中的每個登入而言都是唯一的。 41 Yes
[模式] int 取得鎖定之後產生的模式。

0=NULL - 與所有其他鎖定模式相容 (LCK_M_NL)
1=架構穩定性鎖定 (LCK_M_SCH_S)
2=架構修改鎖定 (LCK_M_SCH_M)
3=共用鎖定 (LCK_M_S)
4=更新鎖定 (LCK_M_U)
5=獨佔鎖定 (LCK_M_X)
6=意圖共享鎖定 (LCK_M_IS)
7=意圖更新鎖定 (LCK_M_IU)
8=意圖獨佔鎖定 (LCK_M_IX)
9=與意圖更新共用 (LCK_M_SIU)
10=與意圖獨佔共用 (LCK_M_SIX)
11=以意圖獨佔更新 (LCK_M_UIX)
12=大量更新鎖定 (LCK_M_BU)
13=金鑰範圍共享/共用 (LCK_M_RS_S)
14=金鑰範圍共用/更新 (LCK_M_RS_U)
15=Key Range 插入 NULL (LCK_M_RI_NL)
16=索引鍵範圍插入共用 (LCK_M_RI_S)
17=索引鍵範圍插入更新 (LCK_M_RI_U)
18=索引鍵範圍插入獨佔 (LCK_M_RI_X)
19=金鑰範圍獨佔共用 (LCK_M_RX_S)
20=金鑰範圍獨佔更新 (LCK_M_RX_U)
21=索引鍵範圍獨佔 (LCK_M_RX_X)
32 Yes
NTDomainName nvarchar 用戶所屬的 Windows 網域。 7 Yes
NTUserName nvarchar Windows 用戶名稱。 6 Yes
ObjectID int 如果可用且適用,取得鎖定的對象標識碼。 22 Yes
ObjectID2 bigint 如果可用且適用,則為相關對象或實體的標識碼。 56 Yes
OwnerID int 1=TRANSACTION

2=CURSOR
3=SESSION
4=SHARED_TRANSACTION_WORKSPACE
5=EXCLUSIVE_TRANSACTION_WORKSPACE
58 Yes
要求識別碼 int 包含語句的要求標識碼。 49 Yes
ServerName nvarchar 要追蹤之 SQL Server 實例的名稱。 26 No
SessionLoginName nvarchar 產生工作階段之使用者的登入名稱。 例如,如果您使用Login1連接到SQL Server,並以Login2的形式執行語句,SessionLoginName 會顯示Login1,而LoginName 會顯示Login2。 此數據行會顯示 SQL Server 和 Windows 登入。 64 Yes
SPID int 事件發生所在之工作階段的識別碼。 12 Yes
StartTime datetime 如果有的話,事件開始的時間。 14 Yes
TextData ntext 與取得之鎖定類型相依的文字值。 這與 中的 resource_description 欄位相同 sys.dm_tran_locks 1 Yes
TransactionID bigint 交易的系統指派標識碼。 4 Yes
類型 int 1=NULL_RESOURCE

2=DATABASE
3=FILE
5=OBJECT
6=PAGE
7=KEY
8=EXTENT
9=RID
10=APPLICATION
11=METADATA
12=AUTONAMEDB
13=HOBT
14=ALLOCATION_UNIT
57 Yes