Showplan XML 事件类

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

Microsoft SQL Server 执行 SQL 语句时,会出现 Showplan XML 事件类。 包括 Showplan XML 事件类以标识 Showplan 运算符。 此事件类将每个事件存储为定义完善的 XML 文档。

当跟踪中包含 Showplan XML 事件类时,其开销将明显影响性能。 查询优化后,Showplan XML 将存储查询计划。 若要将引起的开销降到最低,请将此事件类的使用范围限制在监视主要时段内的特定问题的跟踪中。

Showplan XML 文档具有与之关联的架构。 可以在Microsoft网站中找到此架构,也可以作为Microsoft SQL Server 安装的一部分找到

Showplan XML 事件类数据列

数据列名称 数据类型 说明 列 ID 可筛选
ApplicationName nvarchar 创建到 SQL Server 实例连接的客户端应用程序的名称。 此列由应用程序传递的值填充,而不是由所显示的程序名填充。 10
BinaryData image 查询的预计成本。 2
ClientProcessID int 主机为运行该客户端应用程序的进程分配的 ID。 如果客户端提供了客户端进程 ID,则填充此数据列。 9
DatabaseID int 由 USE database 语句指定的数据库的 ID;如果未对给定实例发出 USE database语句,则为默认数据库的 ID。 如果在跟踪中捕获 ServerName 数据列且服务器可用,SQL Server Profiler 将显示数据库名称。 可使用 DB_ID 函数来确定数据库的值。 3
DatabaseName nvarchar 数据库的名称。 35
Event Class int 事件类型 = 122。 27
EventSequence int 特定事件在请求中的顺序。 51
GroupID int 在其中激发 SQL 跟踪事件的工作负荷组的 ID。 66
HostName nvarchar 正在运行客户端的计算机的名称。 如果客户端提供了主机名,则填充此数据列。 若要确定主机名,请使用 HOST_NAME 函数。 8
Integer Data integer 预计返回的行数。 25
IsSystem int 指示事件是发生在系统进程中还是发生在用户进程中。 1 = 系统,0 = 用户。 60
LineNumber int 显示包含错误的行的编号。 5
LoginName nvarchar 用户的登录名(SQL Server 安全登录名或域\用户名形式的Microsoft Windows 登录凭据)。 11
LoginSID image 登录用户的安全标识号 (SID)。 您可以在 sys.server_principals 目录视图中找到此信息。 服务器中的每个登录名都具有唯一的 SID。 41
NestLevel int 表示 @@NESTLEVEL 所返回的数据的整数。 29
NTDomainName nvarchar 用户所属的 Windows 域。 7
ObjectID int 系统分配的对象 ID。 22
ObjectName nvarchar 引用的对象名。 34
ObjectType int 表示事件中涉及的对象类型的值。 此值对应于 sys.objects 目录视图中的类型列。 有关值的信息,请参阅 ObjectType 跟踪事件列 28
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
TextData ntext 依赖于跟踪中捕获的事件类的文本值。 1
TransactionID bigint 系统分配的事务 ID。 4
XactSequence bigint 用于说明当前事务的标记。 50

另请参阅

扩展事件
sp_trace_setevent (Transact-SQL)
Showplan 逻辑运算符和物理运算符参考