Hash Warning 事件类

适用于: SQL Server Azure SQL 数据库 Azure SQL 托管实例

Hash Warning 事件类可用于监视在哈希操作过程中何时发生哈希递归或哈希终止(哈希释放)。

当生成输入无法装入可用内存时,会发生哈希递归,这将导致输入分割成单独处理的多个分区。 如果这些分区中任何一个仍然大于可用内存,则该分区再拆分成子分区分别进行处理。 此拆分过程将一直继续到每个分区都小于可用内存,或达到最大递归级数(显示在 IntegerData 数据列)。

当哈希操作达到其最大递归级数并转换到替换计划以处理剩余的分区数据时发生哈希释放。 哈希释放通常是由于偏斜数据造成的。

哈希递归和哈希释放会导致服务器的性能降低。 若要消除或降低哈希递归和哈希释放的频率,请执行下列操作之一:

  • 确保正在联接或分组的列上存在统计信息。

  • 如果这些列上存在统计信息,请更新它们。

  • 使用其他类型的联接。 例如,使用 MERGE 或 LOOP 联接(如果适合)。

  • 增加计算机上的可用内存。 当没有足够的内存就地处理查询,因此这些查询需要溢出到磁盘时,会发生哈希递归或哈希释放。

创建或更新联接涉及的列上的统计信息是减少发生哈希递归或哈希释放次数最有效的方法。

注意

另外,“Grace 哈希联接”和“递归哈希联接”两词也用于描述哈希释放。

重要

若要确定查询优化器生成执行计划时 Hash Warning 事件发生的位置,还应在跟踪中收集一个 Showplan 事件类。 可以选择除了 Showplan Text 和 Showplan Text (Unencoded) 事件类(不会返回节点 ID)以外的任何 Showplan 事件类。 Showplan 中的节点 ID 标识查询优化器在生成查询执行计划时执行的每个运算。 这些运算称为“运算符” ,Showplan 中的每个运算符都有一个节点 ID。 Hash Warning 事件的 ObjectID 列与 Showplan 中的节点 ID 对应,因此可确定哪个运算符或运算导致错误。

Hash Warning 事件类的数据列

数据列名称 数据类型 说明 列 ID 可筛选
ApplicationName nvarchar 创建到 SQL Server 实例连接的客户端应用程序的名称。 该列由应用程序传递的值填充,而不是由所显示的程序名填充。 10
ClientProcessID int 主机为运行该客户端应用程序的进程分配的 ID。 如果客户端提供了客户端进程 ID,则填充此数据列。 9
DatabaseID int 由 USE database 语句指定的数据库的 ID;如果未对给定实例发出 USE database 语句,则为默认数据库的 ID。 如果在跟踪中捕获 ServerName 数据列且服务器可用,SQL Server Profiler 将显示数据库名称。 可使用 DB_ID 函数来确定数据库的值。 3
DatabaseName nvarchar 正在其中运行用户语句的数据库的名称。 35
EventClass int 事件类型 = 55。 27
EventSequence int 给定事件在请求中的顺序。 51
EventSubClass int 事件子类的类型。

0 = 递归

1 = 释放
21
GroupID int 在其中激发 SQL 跟踪事件的工作负荷组的 ID。 66
HostName nvarchar 正在运行客户端的计算机的名称。 如果客户端提供了主机名,则填充此数据列。 若要确定主机名,请使用 HOST_NAME 函数。 8
IntegerData int 递归级数(仅限于哈希递归)。 25
IsSystem int 指示事件是发生在系统进程中还是发生在用户进程中。 1 = 系统,0 = 用户。 60
LoginName nvarchar 用户的登录名(SQL Server 安全登录名或域>\<用户名>形式的 <Windows 登录凭据)。 11
LoginSid image 登录用户的安全标识号 (SID)。 您可以在 sys.server_principals 目录视图中找到此信息。 服务器中的每个登录名都具有唯一的 SID。 41
NTDomainName nvarchar 用户所属的 Windows 域。 7
NTUserName nvarchar Windows 用户名。 6
ObjectID int 重新分区所涉及的哈希组的根节点 ID。 与 Showplan 中的节点 ID 对应。 22
RequestID int 包含该语句的请求的 ID。 49
ServerName nvarchar 正在跟踪的 SQL Server 实例的名称。 26
SessionLoginName nvarchar 发起会话的用户的登录名。 例如,如果使用 Login1 连接到 SQL Server,并将语句作为 Login2 执行,SessionLoginName 将显示 Login1,LoginName 显示 Login2。 此列同时显示 SQL Server 和 Windows 登录名。 64
SPID int 发生该事件的会话的 ID。 12
StartTime datetime 该事件(如果存在)的启动时间。 14
TransactionID bigint 系统分配的事务 ID。 4
XactSequence bigint 用于说明当前事务的标记。 50

另请参阅

sp_trace_setevent (Transact-SQL)
联接