SP:Recompile 事件类

SP:Recompile 事件类指示存储过程、触发器或用户定义的函数已被重新编译。在 SQL Server 2005 中,此事件类报告的重新编译发生在语句级别上,而在 SQL Server 2000 中,则发生在批处理级别上。

在 SQL Server 2005 中,跟踪语句级重新编译的首选方法是使用 SQL:StmtRecompile 事件类。从 SQL Server 2005 开始,不推荐使用 SP:Recompile 事件类。有关详细信息,请参阅 SQL:StmtRecompile 事件类执行计划的缓存和重新使用中的“重新编译执行计划”。

SP:Recompile 事件类的数据列

数据列名称 数据类型 说明 列 ID 可筛选

ApplicationName

nvarchar

客户端应用程序的名称,该客户端应用程序创建了指向 Microsoft SQL Server 实例的连接。此列由应用程序传递的值填充,而不是由所显示的程序名填充。

10

ClientProcessID

int

主机为运行该客户端应用程序的进程分配的 ID。如果客户端提供了进程 ID,则填充此数据列。

9

DatabaseID

int

正在运行存储过程的数据库的 ID。若要确定数据库的值,请使用 DB_ID 函数。

3

DatabaseName

nvarchar

正在运行存储过程的数据库的名称。

35

EventClass

int

事件类型 = 37。

27

EventSequence

int

特定事件在请求中的顺序。

51

EventSubClass

int

事件子类类型。指示重新编译的原因。

1 = 架构已更改

2 = 统计已更改

3 = 重新编译 DNR

4 = 所设置的选项已更改

5 = 临时表已更改

6 = 远程行集已更改

7 = 浏览 Perm 的方式已更改

8 = 查询通知环境已更改

9 = MPI 视图已更改

10 = 光标选项已更改

11 = 使用重新编译选项

21

HostName

nvarchar

正在运行客户端的计算机的名称。如果客户端提供了主机名,则填充此数据列。若要确定主机名,请使用 HOST_NAME 函数。

8

IntegerData2

int

在存储过程或批处理中导致重新编译的语句的终止偏移量。如果该语句是其所在批处理中的最后一个语句,则终止偏移量是 -1。

55

IsSystem

int

指示事件是发生在系统进程还是发生在用户进程。1 = 系统,0 = 用户。

60

LoginName

nvarchar

用户的登录名(SQL Server 安全登录名或 Microsoft Windows 登录凭据,格式为“域\用户名”)。

11

LoginSid

image

登录用户的安全标识号 (SID)。您可以在 master 数据库的 syslogins 表中找到此信息。服务器中的每个登录名都具有唯一的 SID。

41

NestLevel

int

存储过程的嵌套级别。

29

NTDomainName

nvarchar

用户所属的 Windows 域。

7

NTUserName

nvarchar

Windows 用户名。

6

ObjectID

int

系统分配的存储过程 ID。

22

ObjectName

nvarchar

触发重新编译的对象的名称。

34

ObjectType

int

表示事件中涉及的对象类型的值。有关详细信息,请参阅ObjectType 跟踪事件列

28

Offset

int

在存储过程或批中导致重新编译的语句的起始偏移量。

61

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

SqlHandle

varbinary

基于即席查询文本或 SQL 对象的数据库和对象 ID 的 64 位哈希运算。可以将该值传递到 sys.dm_exec_sql_text() 以检索关联的 SQL 文本。

63

StartTime

datetime

该事件(如果存在)的启动时间。

14

TextData

ntext

导致语句级重新编译的 Transact-SQL 语句文本。请注意,在 SQL Server 2000 中不填充该数据列,但是在 SQL Server 2005 中将填充该数据列。

1

TransactionID

bigint

系统分配的事务 ID。

4

XactSequence

bigint

用于说明当前事务的标记。

50

请参阅

参考

SQL:StmtRecompile 事件类

其他资源

监视事件
sp_trace_setevent (Transact-SQL)

帮助和信息

获取 SQL Server 2005 帮助