Hash Warning 事件類別
適用於:SQL ServerAzure SQL 資料庫 Azure SQL 受控執行個體
Hash Warning 事件類別可用來監視哈希遞歸或哈希作業期間發生哈希停止的時間。
當組建輸入不符合可用記憶體時,就會發生哈希遞歸,導致將輸入分割成多個個別處理的分割區。 如果其中任何一個分割區仍然無法放入可用的記憶體中,則會分割成個別處理的子分割區。 此分割程式會繼續執行,直到每個分割區符合可用記憶體,或直到達到最大遞歸層級為止(顯示在 IntegerData 資料行中)。
當雜湊作業達到最大遞迴等級時會發生 Hash Bailout,且切換到其他計畫以處理其他的分割資料。 哈希救助通常是因為扭曲的數據而發生。
哈希遞歸和哈希救助會導致伺服器效能降低。 若要消除或減少哈希遞歸和救助的頻率,請執行下列其中一項動作:
請確定已聯結或分組之數據行上有統計數據。
如果數據列上有統計數據,請加以更新。
使用不同類型的聯結。 例如,如果適當,請改用 MERGE 或 LOOP 聯結。
增加電腦上的可用記憶體。 哈希遞歸或救助發生於沒有足夠的記憶體可以就地處理查詢,而且需要溢出到磁碟時。
建立或更新聯結中涉及之數據行的統計數據,是減少發生之哈希遞歸或救助次數的最有效方式。
注意
條件 寬限哈希聯結 和 遞歸哈希聯 結也用來描述哈希救助。
重要
若要判斷查詢優化器產生執行計劃時發生哈希警告事件的位置,您也應該在追蹤中收集 Showplan 事件類別。 您可以選擇任何 Showplan 事件類別,但 Showplan Text 和 Showplan Text (Unencoded) 事件類別除外,不會傳回節點標識符。 Showplan 中的節點標識碼會識別查詢優化器在產生查詢執行計劃時執行的每個作業。 這些作業稱為 運算符,而 Showplan 中的每個運算子都有節點識別碼。 哈希警告事件的 ObjectID 數據行會對應至 Showplans 中的節點識別碼,讓您可以判斷哪一個運算符或作業會造成錯誤。
哈希警告事件類別數據行
數據行名稱 | 資料類型 | 描述 | 資料行識別碼 | 可篩選 |
---|---|---|---|---|
ApplicationName | nvarchar | 建立 SQL Server 實例之連線的用戶端應用程式名稱。 此資料行會填入應用程式所傳遞的值,而不是以程序顯示的名稱填入。 | 10 | Yes |
ClientProcessID | int | 主計算機指派給執行用戶端應用程式的進程標識碼。 如果用戶端提供客戶端進程識別碼,就會填入此資料行。 | 9 | Yes |
DatabaseID | int | 如果指定的實例未發出USE database語句,則為USE database語句或預設資料庫所指定的資料庫標識碼。 如果在追蹤中擷取到 ServerName 資料行且伺服器可用,SQL Server Profiler 便會顯示資料庫的名稱。 請使用 DB_ID 函數判斷資料庫的值。 | 3 | Yes |
DatabaseName | nvarchar | 使用者語句執行所在的資料庫名稱。 | 35 | Yes |
EventClass | int | 事件類型 = 55。 | 27 | No |
EventSequence | int | 要求內指定事件的順序。 | 51 | No |
EventSubClass | int | 事件子類別的類型。 0=遞歸 1=救助 |
21 | Yes |
GroupID | int | SQL 追蹤事件引發之工作負載群組的標識碼。 | 66 | Yes |
HostName | nvarchar | 用戶端執行所在的計算機名稱。 如果用戶端提供主機名,則會填入此數據行。 若要判斷主機名稱,請使用 HOST_NAME 函數。 | 8 | Yes |
IntegerData | int | 遞歸層級(僅限哈希遞歸)。 | 25 | Yes |
IsSystem | int | 指出事件發生在系統進程或用戶進程上。 1 = 系統,0 = 使用者。 | 60 | Yes |
LoginName | nvarchar | 使用者登入的名稱(SQL Server 安全性登入或網域>\<用戶名稱>形式的 <Windows 登入認證)。 | 11 | Yes |
LoginSid | image | 已登入使用者的安全性識別碼(SID)。 您可以在sys.server_principals目錄檢視中找到此資訊。 每一個 SID 對於伺服器中的每個登入而言都是唯一的。 | 41 | Yes |
NTDomainName | nvarchar | 用戶所屬的 Windows 網域。 | 7 | Yes |
NTUserName | nvarchar | Windows 用戶名稱。 | 6 | Yes |
ObjectID | int | 與重新分割相關的哈希小組根目錄節點標識碼。 會對應至 Showplans 中的節點標識碼。 | 22 | Yes |
要求識別碼 | int | 包含陳述式之要求的識別碼。 | 49 | Yes |
ServerName | nvarchar | 正在追蹤之 SQL Server 實例的名稱。 | 26 | |
SessionLoginName | nvarchar | 產生工作階段之使用者的登入名稱。 例如,如果您使用Login1連接到SQL Server,並以Login2的形式執行語句,SessionLoginName 會顯示Login1,而LoginName 會顯示Login2。 此數據行會顯示 SQL Server 和 Windows 登入。 | 64 | Yes |
SPID | int | 事件發生所在之工作階段的識別碼。 | 12 | Yes |
StartTime | datetime | 如果有的話,事件開始的時間。 | 14 | Yes |
TransactionID | bigint | 交易的系統指派標識碼。 | 4 | Yes |
XactSequence | bigint | 描述目前交易的令牌。 | 50 | Yes |