sssym 发表于 2010-1-13 09:34:55

怎样监控sql语句执行时间

我们做了一套报表系统,由于查询条件的不同,查询的等待时间也不一样。为了找出哪些条件的查询时间比较长,公司要求我找出这些语句。

各位大虾,有没有什么好的办法可以让我在使用报表的同时监控数据库语句的执行情况。

用了sql server 的SQL Server Profiler ,但是监控的语句不是程序里面本身编写的语句,而且也很多杂乱无关的东西,效果不好。

PS:我们是J2EE。

sssym 发表于 2010-1-13 13:59:37

顶上去

原点 发表于 2010-1-15 10:40:07

SQL优化?

xavier_007 发表于 2010-1-15 15:30:51

在执行前得到时间,执行sql后得到时间
然后相减不可以么?

mlujian 发表于 2010-1-16 09:42:02

學習關注中

cl4631439 发表于 2010-1-18 13:27:22

你这个时间不是重点,重点是哪条语句慢,我理解对吗

我用的2005,服务器上的是2000,我们可以在执行程序之前,打开SQL Server Profiler ,然后再打开 管理——活动监视器
如果语句执行的很慢的话,会出现很多的锁,在活动监视器中找到出现锁最多的“进程ID”,然后回到SQL Server Profiler 里,活动监视器中的“进程ID”就是SQL Server Profiler里的SPID,这样对应的SQL Server Profiler里的TextDate就是运行慢的语句

这是之前别人教我这么做的,我知道怎么做,但是,也只能叙述成这样了,希望能帮到你

PrefTest 发表于 2010-11-24 16:00:42

回复 1# sssym


    用事件探察器跟踪,然后在跟踪文件中查找时间长的SQL语句:

the following query returns all events with greater than 1000 milliseconds duration from trace.trc file in a table format:
SELECT * FROM ::fn_trace_gettable(‘c:\trace.trc’, default) WHERE Duration > 1000
For more information, see "fn_trace_gettable" in SQL Server Books Online.

peag 发表于 2010-11-25 09:00:58

可以把你用profile检测到的sql语句拿到执行计划去看下,具体那块出问题了就整那块~

gaha 发表于 2014-4-25 09:18:22

\timing,SQL中有类似的开关,每个厂家的开关名称不一样,但是原理一样,打开开关之后,执行SQL后会告诉你执行使用的时间,单位是ms。

具体开关名,可以查手册。



页: [1]
查看完整版本: 怎样监控sql语句执行时间