SQLSERVER语句的执行时间显示的统计结果是什么意思
程序员文章站
2023-12-12 08:32:28
在sql语句调优的时候,大部分都会查看语句执行时间,究竟sqlserver显示出来的统计结果是什么意思? 下面看一下例子 比较简单的语句: 复制代码 代码如下: 1 set...
在sql语句调优的时候,大部分都会查看语句执行时间,究竟sqlserver显示出来的统计结果是什么意思?
下面看一下例子
比较简单的语句:
1 set statistics time on
2 use [pratice]
3 go
4 select * from [dbo].[orders]
结果:
sql server 分析和编译时间:
cpu 时间 = 0 毫秒,占用时间 = 0 毫秒。
sql server 执行时间:
cpu 时间 = 0 毫秒,占用时间 = 0 毫秒。
sql server 执行时间:
cpu 时间 = 0 毫秒,占用时间 = 0 毫秒。
sql server 分析和编译时间:
cpu 时间 = 0 毫秒,占用时间 = 0 毫秒。
(121317 行受影响)
sql server 执行时间:
cpu 时间 = 109 毫秒,占用时间 = 2506 毫秒。
语句的cpu时间分编译阶段和执行阶段。优化者要先搞清楚这两个阶段各用了多少cpu资源。
然后,再看有没有优化降低cpu使用量的可能
上面的cpu时间是指:执行语句的时间
而占用时间是指:从磁盘读取数据再处理总的使用时间
编译阶段:
sql server 分析和编译时间:
执行阶段:
sql server 执行时间:
下面看一下例子
比较简单的语句:
复制代码 代码如下:
1 set statistics time on
2 use [pratice]
3 go
4 select * from [dbo].[orders]
结果:
复制代码 代码如下:
sql server 分析和编译时间:
cpu 时间 = 0 毫秒,占用时间 = 0 毫秒。
sql server 执行时间:
cpu 时间 = 0 毫秒,占用时间 = 0 毫秒。
sql server 执行时间:
cpu 时间 = 0 毫秒,占用时间 = 0 毫秒。
sql server 分析和编译时间:
cpu 时间 = 0 毫秒,占用时间 = 0 毫秒。
(121317 行受影响)
sql server 执行时间:
cpu 时间 = 109 毫秒,占用时间 = 2506 毫秒。
语句的cpu时间分编译阶段和执行阶段。优化者要先搞清楚这两个阶段各用了多少cpu资源。
然后,再看有没有优化降低cpu使用量的可能
上面的cpu时间是指:执行语句的时间
而占用时间是指:从磁盘读取数据再处理总的使用时间
编译阶段:
sql server 分析和编译时间:
执行阶段:
sql server 执行时间: