profiler跟踪事件存为表之后性能分析工具
使用profiler建立跟踪,将跟踪结果存到表中,使用下面存储过程执行 exec temp_profiler 'tra_tablename'对表数据进行处理归类,然后进行性能分析
1.先建存储过程
2.再执行下面的查询
--处理trace数据
--exec temp_profiler 'temp_profiler201509061618'
select top 10000 * from temp_profiler201509061618 order by reads desc
--1)查出最耗时的语句或过程
select * from temp_profiler201509061618_stat order by total_duration desc
--3) 统计某个过程或者sql语句的个数
select proc_sql_id ,count(1) counts from temp_profiler201509061618 group by proc_sql_id order by counts desc
--2)查询某个过程或者sql语句详情
select * from temp_profiler201509061618 where proc_sql_id = 3--
select * from temp_profiler201509061618 where proc_sql_id = 22--
select * from temp_profiler201509061618 where proc_sql_id = 18--
exec temp_profiler 'temp_profiler201508210920'
select top 10000 * from temp_profiler201508210920 order by reads desc
select * from temp_profiler201508210920_stat order by total_duration desc
select proc_sql_id ,count(1) counts from temp_profiler201508210920 group by proc_sql_id order by counts desc
select * from temp_profiler201508210920 where proc_sql_id = 2--5761
select * from temp_profiler_2015060816 where textdata like 'exec PageList%'
USE [temp_profiler]
GO /****** Object: StoredProcedure [dbo].[temp_profiler] Script Date: 08/26/2015 10:16:31 ******/
SET ANSI_NULLS ON
GO SET QUOTED_IDENTIFIER ON
GO -- =============================================
--http://www.cnblogs.com/davidhou
-- Author: <houpeidong>
-- Create date: <20150611>
-- Description: <profiler抓取到的数据存入表中,此存储过程功能为性能分析工具,表名不能加中括号>
-- =============================================
CREATE PROCEDURE [dbo].[temp_profiler]
@tblName NVARCHAR(500)
as
begin SET NOCOUNT ON --DECLARE @tblName NVARCHAR(500) ;
--set @tblName = 'temp_profiler_20151' ; DECLARE @sqlStr NVARCHAR(2000); --10. 对trace表的数据进行处理前的一些准备:
-- 时间改为毫秒
SET @sqlStr = N'update ' + @tblName +' set duration = duration / 1000 where duration is not null ';
EXECUTE sp_executesql @sqlStr ; --update temp_profiler_2015060917 set duration = duration / 1000 where duration is not null -- 时间改为毫秒 --修改 textdata 为 nvarchar(max)类型,因为textdata默认保存为ntext类型,处理不方便
SET @sqlStr = N'alter table '+@tblName+' alter column textdata nvarchar(max)';
EXECUTE sp_executesql @sqlStr ;
--alter table temp_profiler_2015060917 alter column textdata nvarchar(max) --新增两个字段
SET @sqlStr = N'alter table '+@tblName+' add proc_sql nvarchar(max)';
EXECUTE sp_executesql @sqlStr ;
--alter table temp_profiler_2015060917 add proc_sql nvarchar(max) -- 保存该textdata调用的存储过程,原始sql等; SET @sqlStr = N'alter table '+@tblName+' add proc_sql_id int';
EXECUTE sp_executesql @sqlStr ;
--alter table temp_profiler_2015060917 add proc_sql_id int -- 为存储过程和原始sql指定一个编号 --11. 处理trace数据
-- 1)找出执行的sql脚本(带参数) ,更新到 proc_sql 字段
SET @sqlStr = N'
update '+@tblName+'
set proc_sql = replace(left(textdata,charindex('''''',N'''''',textdata) - 1),''exec sp_executesql N'''''','''')
where (proc_sql is null or proc_sql = '''' )
and charindex(''exec sp_executesql N'', textdata ) = 1
';
EXECUTE sp_executesql @sqlStr ; --2)找出执行的存储过程,更新到 proc_sql 字段
SET @sqlStr = N'
update '+@tblName+'
set proc_sql =
replace(
replace(
left(
right(textdata,len(textdata) - charindex(''exec '',textdata) + 3),
charindex(''@'',
right(textdata,len(textdata) - charindex(''exec '',textdata) + 3)
)
),''exec '','''')
,''@'','''')
where (proc_sql is null or proc_sql = '''' )
and charindex(''exec '',textdata) > 0
';
EXECUTE sp_executesql @sqlStr ; --3)找出没有参数的sql脚本,更新到 proc_sql 字段
--update temp_profiler_2015060917 set proc_sql = textdata where proc_sql is null and textdata is not null
SET @sqlStr = N'update '+@tblName+' set proc_sql = textdata where proc_sql is null and textdata is not null'
EXECUTE sp_executesql @sqlStr ; --12. 统计
--1)新建表,用于保存统计数据,trace_20130910每个proc_sql对应一行
SET @sqlStr = N'
create table ['+@tblName+'_stat]
(
id int identity(1,1) primary key,
databaseid int,
proc_sql nvarchar(max), -- 对应trace_20130910的proc_sql
total_duration bigint, -- 总耗时
max_duration int, -- 该语句最大耗时
min_duration int, -- 该语句最小耗时
rate_duration int -- 所耗时间百分比
)
';
EXECUTE sp_executesql @sqlStr ; --2)生成统计数据,存入1)步的表中 trace_20130910_stat]
SET @sqlStr = N'
;with cte
(
databaseid,
proc_sql,
total_duration,
max_duration ,
min_duration
) as
(select databaseid,
proc_sql,
sum(duration) as total_duration,
max(duration) as max_duration,
min(duration) as min_duration
from '+@tblName+'
where proc_sql is not null and proc_sql <> ''''
group by databaseid,proc_sql
)
, cte2 as
(-- 总耗时,用来计算百分比
select sum(total_duration) as total_duration from cte
)
insert into ['+@tblName+'_stat]
(
databaseid,
proc_sql,
total_duration,
max_duration ,
min_duration ,
rate_duration
)
select
databaseid,
proc_sql,
total_duration,
max_duration ,
min_duration ,
100 * total_duration / ( select total_duration from cte2 ) as rate_duration
from cte
order by rate_duration desc
';
EXECUTE sp_executesql @sqlStr ; -- 3)更新记录表[trace_20130910]的 proc_sql_id
SET @sqlStr = N'
update ['+@tblName+'] set proc_sql_id = b.id
from ['+@tblName+'] a inner join ['+@tblName+'_stat] b
on a.databaseid = b.databaseid and a.proc_sql = b.proc_sql
';
EXECUTE sp_executesql @sqlStr ;
end ;
GO
profiler跟踪事件存为表之后性能分析工具的更多相关文章
- CLR Profiler 性能分析工具
CLR Profiler 性能分析工具 CLR Profiler 性能分析工具 CLR Profiler 有两个版本,分别用于CLR1.1 和 CLR2.0,至于CLR4试了一些也可以,但不知道是否完 ...
- Java 性能分析工具 , 第 1 部分: 操作系统工具
引言 性能分析的前提是将应用程序内部的运行状况以及应用运行环境的状况以一种可视化的方式更加直接的展现出来,如何来达到这种可视化的展示呢?我们需要配合使用操作系统中集成的程序监控工具和 Java 中内置 ...
- 11个Visual Studio代码性能分析工具
软件开发中的性能优化对程序员来说是一个非常重要的问题.一个小问题可能成为一个大的系统的瓶颈.但是对于程序员来说,通过自身去优化代码是十分困难的.幸运的是,有一些非常棒的工具可以帮助程序员进行代码分析和 ...
- 系统级性能分析工具 — Perf
从2.6.31内核开始,linux内核自带了一个性能分析工具perf,能够进行函数级与指令级的热点查找. perf Performance analysis tools for Linux. Perf ...
- 系统级性能分析工具perf的介绍与使用[转]
测试环境:Ubuntu16.04(在VMWare虚拟机使用perf top存在无法显示问题) Kernel:3.13.0-32 系统级性能优化通常包括两个阶段:性能剖析(performance pro ...
- .NET 11 个 Visual Studio 代码性能分析工具
原文地址 软件开发中的性能优化对程序员来说是一个非常重要的问题.一个小问题可能成为一个大的系统的瓶颈.但是对于程序员来说,通过自身去优化代码是十分困难的.幸运的是,有一些非常棒的工具可以帮助程序员进行 ...
- Android 常用的性能分析工具详解:GPU呈现模式, TraceView, Systrace, HirearchyViewer(转)
此篇将重点介绍几种常用的Android性能分析工具: 一.Logcat 日志 选取Tag=ActivityManager,可以粗略地知道界面Displaying的时间消耗.当我们打开一个Activit ...
- 11 个 Visual Studio 代码性能分析工具
软件开发中的性能优化对程序员来说是一个非常重要的问题.一个小问题可能成为一个大的系统的瓶颈.但是对于程序员来说,通过自身去优化代码是十分困难的.幸运的是,有一些非常棒的工具可以帮助程序员进行代码分析和 ...
- 系统级性能分析工具 — Perf【转】
转自:https://blog.csdn.net/zhangskd/article/details/37902159 版权声明:本文为博主原创文章,转载请注明出处. https://blog.csdn ...
随机推荐
- SpringMvc配置详解
在此做一个对Mvc的复习,便于以后快速复习mvc配置. 开发环境 : IDe :iDEA JDK:1.8 使用的框架技术:Mybtais ,Spring,Spring MVC 数据源选用Dbcp 首先 ...
- JavaScript学习笔记 isPrototypeOf和hasOwnProperty使用区别
1.isPrototypeOf isPrototypeOf是用来判断指定对象object1是否存在于另一个对象object2的原型链中,是则返回true,否则返回false. 格式如下: object ...
- php 对二维数组的某个字段公用排序的方法
function array_sort($arr ,$keys,$order=0){ if(!is_array($arr)){ return false; } $keysvalue=array(); ...
- Codeforces Round #348 (VK Cup 2016 Round 2, Div. 2 Edition) E. Little Artem and Time Machine 树状数组
E. Little Artem and Time Machine 题目连接: http://www.codeforces.com/contest/669/problem/E Description L ...
- Codeforces Round #300 D. Weird Chess 水题
D. Weird Chess Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/538/proble ...
- 【MongoDB】windows下搭建Mongo主(Master)/从(slave)数据库同步
在前面一系列的文章中.我们讲述了mongodb的基本操作,高级查询以及索引的使用. 该篇博客主要说明在windows系统怎样创建主从数据库同步: 须要启动两个mongoDb文档数据库,一个是主模式启动 ...
- Read UNIQUE ID and flash size method for stm32
/* 读取stm32的unique id 与 flash size */ /* func: unsigned int Read_UniqueID_Byte(unsigned char offset) ...
- 《UNIX环境高级编程》笔记--errno是否是线程安全的?
当UNIX函数出错时,常常返回一个负数,而且整形变量errno通常被设置为含有附加信息的一个值,例如,open函数如成功,返回 一个非负文件描述符,如果出错就返回-1,在open出错时,有大约15种不 ...
- jquery开发之第一个程序
前一段时间学习了js和css.可是发现好多的程序里面都用到了jquery当时本来想着先吧js弄熟了 再搞这个.后来发现不行,好多的程序好像是有益和自己为难似的,所以我决定接下来认认真真的把jquery ...
- Linux文件目录的一点小结
转载:http://blog.chinaunix.net/uid-29171357-id-3889735.html 1. 相关指令: chgrp:改变文件所属用户组 点击(此处)折叠或打开 ...