位置: 编程技术 - 正文

SQLSERVER收集语句运行的统计信息并进行分析(sql数据采集)

编辑:rootadmin
对于语句的运行,除了执行计划本身,还有一些其他因素要考虑,例如语句的编译时间、执行时间、做了多少次磁盘读等。如果DBA能够把问题语句单独测试运行,可以在运行前打开下面这三个开关,收集语句运行的统计信息。 这些信息对分析问题很有价值。 SET STATISTICS TIME ON -------------------------------------------------------------------------------- 请先来看看SET STATISTICS TIME ON会返回什么信息。先运行语句: 除了结果集之外,SQLSERVER还会返回下面这两段信息 大家知道SQLSERVER执行语句是分以下阶段:分析-》编译-》执行 根据表格的统计信息分析出比较合适的执行计划,然后编译语句,最后执行语句下面说一下上面的输出是什么意思: -------------------------------------------------------------------------------- 1、CPU时间 :这个值的含义指的是在这一步,SQLSERVER所花的纯CPU时间是多少。也就是说,语句花了多少CPU资源 2、占用时间 :此值指这一步一共用了多少时间。也就是说,这是语句运行的时间长短,有些动作会发生I/O操作,产生了I/O等待,或者是遇到阻塞、产生了阻塞等待。总之时间用掉了,但是没有用CPU资源。所以占用时间比CPU时间长是很正常的 ,但是CPU时间是语句在所有CPU上的时间总和。如果语句使用了多颗CPU,而其他等待几乎没有,那么CPU时间大于占用时间也是正常的 3、分析和编译时间:这一步,就是语句的编译时间。由于语句运行之前清空了所有执行计划,SQLSERVER必须要对他编译。 这里的编译时间就不为0了。由于编译主要是CPU的运算,所以一般CPU时间和占用时间是差不多的。如果这里相差比较大,就有必要看看SQLSERVER在系统资源上有没有瓶颈了。 这里他们是一个毫秒,一个是毫秒 4、SQLSERVER执行时间: 语句真正运行的时间。由于语句是第一次运行,SQLSERVER需要把数据从磁盘读到内存里,这里语句的运行发生了比较长的I/O等待。所以这里的CPU时间和占用时间差别就很大了,一个是毫秒,而另一个是毫秒 总的来讲,这条语句花了++=毫秒,其中CPU时间为+=毫秒。语句的主要时间应该是都花在了I/O等待上 现在再做一遍语句,但是不清除任何缓存 这次比上次快很多。输出时间统计信息是: 由于执行计划被重用,“SQL分析和编译时间” CPU时间是0,占用时间是0 由于数据已经缓存在内存里,不需要从磁盘上读取,SQL执行时间 CPU时间是,占用时间这次和CPU时间非常接近,是。这里省下运行时间-=毫秒,从这里可以再次看出,缓存对语句执行性能起着至关重要的作用 为了不影响其他测试,请运行下面的语句关闭SET STATISTICS TIME ON SET STATISTICS IO ON -------------------------------------------------------------------------------- 这个开关能够输出语句做的物理读和逻辑读的数目。对分析语句的复杂度有很重要的作用 还是以刚才那个查询作为例子 他的返回是: (4 行受影响) 表 'SalesOrderDetail_test'。扫描计数 5,逻辑读取 次,物理读取 0 次,预读 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。 各个输出的含义是: -------------------------------------------------------------------------------- 表:表的名称。这里的表就是SalesOrderDetail_test 扫描计数:执行的扫描次数。按照执行计划,表格被扫描了几次。一般来讲大表扫描的次数越多越不好。唯一的例外是如果执行计划选择了并发运行, 由多个thread线程同时做一个表的读取,每个thread读其中的一部分,但是这里会显示所有thread的数目。也就是有几个thread在并发做, 就会有几个扫描。这时数目大一点没问题的。逻辑读取:从数据缓存读取的页数。页数越多,说明查询要访问的数据量就越大,内存消耗量越大,查询也就越昂贵。 可以检查是否应该调整索引,减少扫描的次数,缩小扫描范围 物理读取:从磁盘读取的页数 预读:为进行查询而预读入缓存的页数 物理读取+预读:就是SQLSERVER为了完成这句查询而从磁盘上读取的页数。如果不为0,说明数据没有缓存在内存里。运行速度一定会受到影响 LOB逻辑读取:从数据缓存读取的text、ntext、image、大值类型(varchar(max)、nvarchar(max)、varbinary(max))页的数目 LOB物理读取:从磁盘读取的text、ntext、image、大值类型页的数目 LOB预读:为进行查询而放入缓存的text、ntext、image、大值类型页的数目 然后再来运行一遍,不清空缓存 结果集返回: 这次逻辑读取不变,还是页。但是物理读取和预读都是0了。说明数据已经缓存在内存里第二次运行不需要再从磁盘上读一遍,节省了时间为了不影响其他测试,请运行下面语句关闭SET STATISTICS IO ON SET STATISTICS PROFILE ON -------------------------------------------------------------------------------- 这是三个设置中返回最复杂的一个,他返回语句的执行计划,以及语句运行在每一步的实际返回行数统计。 通过这个结果,不仅可以得到执行计划,理解语句执行过程,分析语句调优方向,也可以判断SQLSERVER是否 选择了一个正确的执行计划。 返回的结果集很长,下面说一下重要字段 --------------------------------------------------------------------------------

注意:这里是从最下面开始向上看的,也就是说从最下面开始一直执行直到得到结果集所以(行1)里的rows字段显示的值就是这个查询返回的结果集。 而且有多少行表明SQLSERVER执行了多少个步骤,这里有6行,表明SQLSRVER执行了6个步骤!! Rows:执行计划的每一步返回的实际行数 Executes:执行计划的每一步被运行了多少次 StmtText:执行计划的具体内容。执行计划以一棵树的形式显示。每一行都是运行的一步,都会有结果集返回,也都会有自己的cost EstimateRows:SQLSERVER根据表格上的统计信息,预估的每一步的返回行数。在分析执行计划时,我们会经常将Rows和EstimateRows这两列做对比,先确认SQLSERVER预估得是否正确,以判断统计信息是否有更新 EstimateIO:SQLSERVER根据EstimateRows和统计信息里记录的字段长度,预估的每一步会产生的I/O cost EstimateCPU:SQLSERVR根据EstimateRows和统计信息里记录的字段长度,以及要做的事情的复杂度,预估每一步会产生的CPU cost TotalSubtreeCost:SQLSERVER根据EstimateIO和EstimateCPU通过某种计算公式,计算出每一步执行计划子树的cost (包括这一步自己的cost和他的所有下层步骤的cost总和),下面介绍的cost说的都是这个字段值 Warnings:SQLSERVER在运行每一步时遇到的警告,例如,某一步没有统计信息支持cost预估等。 Parallel:执行计划的这一步是不是使用了并行的执行计划 从上面结果可以看出执行计划分成4步,其中第一步又分成并列的两个子步骤 步骤a1(第5行):从[SalesOrderHeader_test]表里找出所有a.[SalesOrderID]> AND a.[SalesOrderID]<的值 因为表在这个字段上有一个聚集索引,所以SQL可以直接使用这个索引的seek SQL预测返回条记录,实际也就返回了条记录.。这个预测是准确的。这一步的cost是0.(totalsubtreecost) 步骤a2(第6行):从[SalesOrderDetail_test]表里找出所有 a.[SalesOrderID]> AND a.[SalesOrderID]<的值 因为表在这个字段上有一个非聚集索引,所以SQL可以直接使用这个索引的seek 这里能够看出SQL聪明的地方。虽然查询语句只定义了[SalesOrderHeader_test]表上有a.[SalesOrderID]> AND a.[SalesOrderID]<过滤条件,但是根据语义分析,SQL知道这个条件在[SalesOrderDetail_test]上也为真。所以SQL选择先把这个条件过滤然后再做join。这样能够大大降低join的cost 在这一步SQL预估返回条记录,实际返回条。cost是0.,也不高 步骤b(第4行):将a1和a2两步得到的结果集做一个join。因为SQL通过预估知道这两个结果集比较大,所以他直接选择了Hash Match的join方法。 SQL预估这个join能返回行,实际返回行。因为SQL在两张表的[SalesOrderID]上都有统计信息,所以这里的预估非常准确 这一步的cost等于totalsubtreecost减去他的子步骤,0.-0.-0.=0.。由于预估值非常准确,可以相信这里的cost就是实际每一步的cost 步骤c(第3行):在join返回的结果集基础上算count(*)的值这一步比较简单,count(*)的结果总是1,所以预测值是正确的。 其实这一步的cost是根据上一步(b)join返回的结果集大小预估出来的。我们知道步骤b的预估返回值非常准确,所以这一步的预估cost也不会有什么大问题 这棵子树的cost是0.,减去他的子节点cost,他自己的cost是0.-0.=0.。是花费很小的一步 步骤b(第2行):将步骤c返回的值转换为int类型,作为结果返回 这一步是上一步的继续,更为简单。convert一个值的数据类型所要的cost几乎可以忽略不计。所以这棵子树的cost和他的子节点相等,都是0.。 也就是说,他自己的cost是0 通过这样的方法,用户可以了解到语句的执行计划、SQLSERVER预估的准确性、cost的分布 最后说一下:不同SQLSERVER版本,不同机器cost可能会不一样,例如SQL ,SQL

推荐整理分享SQLSERVER收集语句运行的统计信息并进行分析(sql数据采集),希望有所帮助,仅作参考,欢迎阅读内容。

SQLSERVER收集语句运行的统计信息并进行分析(sql数据采集)

文章相关热门搜索词:sqlserver实时数据采集,sql server集合查询,sqlserver语录,sqlserver语句大全,sql数据采集,sql数据采集,sqlserver实时数据采集,sqlserver实时数据采集,内容如对您有帮助,希望把文章链接给更多的朋友!

SQLSERVER语句的执行时间显示的统计结果是什么意思 在SQL语句调优的时候,大部分都会查看语句执行时间,究竟SQLSERVER显示出来的统计结果是什么意思?下面看一下例子比较简单的语句:1SETSTATISTICSTIMEON2US

你真的了解触发器么 数据实时同步更新问题剖析 当我们想更新一张动态表的时候(即:表中的数据不断的添加),也许我们会用数据库代理,通过写作业,然后让他定时查询动态表中最新添加的数据,然

存储过程实现订单号,流水单号(8位)的详细思路 此文章是借鉴园中的各位大神的,本人只是略作修改。有不好的地方,欢迎吐槽。先写实现思路,然后再贴上代码1.建立存储过程,声明输出参数@indentNu

标签: sql数据采集

本文链接地址:https://www.jiuchutong.com/biancheng/347852.html 转载请保留说明!

上一篇:SQLSERVER中得到执行计划的两种方式(sql server怎么执行)

下一篇:SQLSERVER语句的执行时间显示的统计结果是什么意思(sql server执行语句)

  • 小规模纳税人升级一般纳税人流程
  • 个人所得税如何计算
  • 物业公司代收电费怎么开票
  • 公司借款受托支付是什么
  • 土地入固定资产还是无形资产
  • 工程项目估算收入要缴税吗
  • 车辆租赁发票税点
  • 设定受益计划会计处理案例
  • 坏账准备递延所得税资产怎么算
  • 企业应收票据贴现给银行所获得的现金计入现金流量表
  • 工会经费计提多了跨年
  • 补提折旧调整分录
  • 劳务费发票可以含材料费吗
  • 关于城建税教育费附加地方教育附加的计算
  • 企业购入交易性金融资产支付的交易费用
  • 增值税发票小数点后面小数不能打印
  • 工程会计的主要工作
  • 企业计提房产税的会计处理正确的是
  • 清除不必要的内存
  • 抵偿债务会计处理
  • 外贸企业有哪些公司青岛
  • PHP:pg_connection_busy()的用法_PostgreSQL函数
  • 写入缓存策略无法更改
  • dsm是什么文件
  • h5能不能自动播放
  • 企业收到对外投资收益交所得税吗
  • 结转损益类收入科目的余额会计分录
  • vue组件引入外部js
  • nvm 安装node
  • thinkphp框架结构
  • 员工报销医药费的会计分录
  • 小三用英语怎么写?
  • 不同情况不同处理的句子
  • python wraps函数
  • mysql的命名规则
  • mongodb简单使用
  • 接待客户的住宿费发票是开谁的
  • 错开发票所需要提供的资料和时效要求是?
  • sqlserver2000分页
  • 企业福利费账务处理
  • 土地使用权转让合法吗
  • 娱乐服务计费销售额包括
  • 会计科目长期待摊费用
  • 生产成本如何结转
  • 实际缴纳的税金比应交的多的部分记入什么科目
  • 所得税费用科目的期末余额应直接转入
  • 预付款开了发票
  • 暂估入库冲回与退回区别
  • 无奖有票是什么意思
  • 购买苗木怎么做政府会计分录
  • 递延所得税资产怎么计算
  • 总部结算什么意思
  • 上海残疾人就业保障金计算公式
  • 工资条上为什么不显示生育险
  • 公司转让二手车需要缴纳什么税
  • 经营地址怎么变更
  • 现金支票办理电话
  • sql server2012操作步骤
  • mysql全部语法
  • sql server 错误
  • 如何在mac系统和win10之间转换
  • windows8主题桌面
  • es6中的class常见使用场景
  • Python插件怎么安装
  • cocos2dx lua在sublime下的插件安装及查看定义
  • unity ulua
  • js的定时器函数
  • 怎么利用python爬虫爬数据
  • echarts图表
  • Android带有注册界面的简单app
  • js获取当前点击事件的节点
  • 安卓仿平板
  • js控制浏览器返回按钮
  • 关于税收的问题及答案
  • ca登录的用户名和密码分别是什么
  • 股权转让本人不签字可以吗
  • 如何查询甘肃省志愿录取状态
  • 新疆塔城靠近俄罗斯吗
  • 税收筹划与避税的性质相同
  • 职称申报后附件打不开
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设