2、事件
一个事件表现SQL Server中执行的各种活动。这些活动可以简单地分类为事件类,游标事件,锁事件,存储过程事件和T-SQL事件是常见的事件类。
对于性能分析,主要对SQL Server上执行的各种活动的资源压力水平的事件感兴趣。资源压力主要包含如下内容:
- SQL活动涉及哪一类的CPU使用?
- 使用了多少内存?
- 涉及多少I/0操作?
- SQL活动执行了多长时间?
- 特定的查询执行的频率有多高?
- 查询面对哪类错误和警告?
下面给出跟踪查询结束的事件:
| 事件类 | 事件 | 说明 |
| Stored Procedures | RPC:Completed | RPC完成事件 |
| SP:Completed | 存储过程完成事件 | |
| SP:StmtCompleted | 在存储过程中一条SQL语句完成事件 | |
| T-SQL | SQL:BatchCompleted | T-SQL批完成事件 |
| SQL:StmtCompleted | 一条T-SQL语句完成事件 |
RPC事件表示存储过程使用远程过程调用(RPC)机制通过OLEDB命令执行。如果一个数据库应用程序使用T-SQL EXECUTE语句执行一个存储过程,那么存储过程将被转化为一个SQL批而不是一个RPC。RPC请求通常比EXECUTE请求快,因为它绕过了SQL Server中的许多语句解析和参数处理。
T-SQL由一条或多条T-SQL语句组成。语句或T-SQL语句在存储过程中也是单独和离散的。用SP:StmtCompleted或SQL:StmtCompleted事件捕捉单独的语句可能是代价很高的操作,这取决于单独语句的数量。假设系统中的每个存储过程包含且只有一条T-SQL语句。在这种情况下,完成的语句集合相当小。现在假定过程中有多条语句,而且这些过程中有些使用其他语句调用其他过程。收集所有这些额外的数据现在变成系统上非常厉害的负载。在生产机上一定要慎用。
现在回到那个事件选择面板,只有已经被选择的事件才会被显示。如果想显示所有可供选择的事件,则只需选中“显示所有事件”单选框,要添加一个跟踪事件,在Event列中查找一个事件类下的事件,并单击其左边的检查框;要删除不需要的事件,取消选中的事件选择框。
本文探讨SQL Server中各种事件类别的作用,包括存储过程、T-SQL语句及RPC事件,阐述如何通过跟踪查询结束事件进行性能分析,特别关注资源压力水平,如CPU使用率、内存消耗、I/O操作次数、执行时间和查询频率。
7475

被折叠的 条评论
为什么被折叠?



