在MSSQL中,查看较慢语句的执行计划,就是一个比较直观的方式,

如果查看执行计划呢:

1.从右到左,从上到下的顺序阅读执行计划
2.执行计划中每个图标代表一个运算符,总开销为100%
3.数据从右向左在两个操作符之间流动,由一个连接箭头表示。
4.操作符之间连接箭头的宽度是传输行数的图形表示。
5.同一列的两个操作符之间的连接机制将是嵌套的循环连接,Hash    匹配或者合并连接。

  1. 识别执行计划中开销较大的步骤

  1. 关注较高开销的节点,一般是表扫描、假脱机、排序等运算(如上列中的排序)

b.查看节点之间连接箭头的宽度。

箭头的宽度代表传输的数据量大小。

分析箭头左边的节点为什么需要这么多行,是否可以过滤。

检查箭头的属性,实际的行与估计的行相差很大可能是统计信息过时。

c.寻找hash连接操作。对于小的结果集,嵌套的循环连接通常是首选的连接 技术。

d.寻找书签查找操作。大结果集的书签操作可能造成大量的逻辑读。

e.寻找执行排序操作的步骤。这表明数据没有以正确的排序进行检索。

  1. 分析索引有效性

a.数据检索操作

通过查看执行计划中该表的数据检索机制,来判断对该表的查询是否高效。

  1. 查找优于扫描。

  1. RID查找与键查找

键查找优于rid查找,建议对表都加上聚集索引

  1. 分析连接有效性

a. Hash连接

Hash连接有两个输入—建立输入和探查输入。较小数据量的做为建立输入。

在建立阶段,建立输入被扫描或计算,并在内存中建立hash表,每个行根据计算的hash键值被插入的hash表元中。

在探查阶段,对于每个探查行计算hash键值;与hash表元进行匹配。

b. 合并连接

如果连接输入列上已经排序,优化器会为其选择合并连接,合并连接比  Hash匹配更快。

查询优化器使用hash连接高效处理大的、未排序、没有索引的输入。

c.嵌套循环连接

嵌套循环连接使用一个连接作为外部输入表,另一个作为内部输入表。

外部循环逐行扫描外部输入表,内部循环为每一个外部行执行一次,搜索匹  配行。

如果外部输入数据量较小,内部输入大但有索引,嵌套循环连接时非常有效的。

mssql执行计划查看的一些知识的更多相关文章

  1. MSSQL优化之————探索MSSQL执行计划

    最近总想整理下对MSSQL的一些理解与感悟,却一直没有心思和时间写,晚上无事便写了一篇探索MSSQL执行计划,本文讲执行计划但不仅限于讲执行计划. 网上的SQL优化的文章实在是很多,说实在的,我也曾经 ...

  2. PL/SQL执行计划查看

    一.如何查看PLSQL的执行计划 在SQl Window窗口输入sql语句,然后按键"F5",就会进入执行计划查看界面. 二.界面说明 首先我们看第二行有几个属性可以选“Tree” ...

  3. 执行计划查看,autotrace工具的使用

    ---工具的简单介绍   001啥是autotrace,翻译自动跟踪,跟踪什么额? SQL的执行过程   我们老是讲ORACLE体系结构里面,共享池有个组件库高速缓存,存放SQL语句执行计划   什么 ...

  4. MySql 的SQL执行计划查看,判断是否走索引

    在select窗口中,执行以下语句: set profiling =1; -- 打开profile分析工具show variables like '%profil%'; -- 查看是否生效show p ...

  5. [terry笔记]oracle里的执行计划-查看

    内容主要来自看书学习的笔记,如下记录了常见查询执行计划的方法. 2.2 如何查看执行计划 1.explain plan 2.dbms_xplan包 3.autotrace 4.10046事件 5.10 ...

  6. 看懂MSSQL执行计划,分析SQL语句执行情况

    打开SQL执行计划窗口 执行计划的图表是从右向左看的 SQL Server有几种方式查找数据记录 [Table Scan] 表扫描(最慢),对表记录逐行进行检查 [Clustered Index Sc ...

  7. mysql 执行计划查看

    使用explain关键字可以模拟优化器执行SQL查询语句,从而知道MySQL是如何处理你的SQL语句的,分析你的查询语句或是表结构的性能瓶颈.explain执行计划包含的信息 其中最重要的字段为:id ...

  8. mysql执行计划查看工具explain

    在优化sql语句时,我们经常会用到explain语句,这里对explain语句做一个详细的总结说明. The EXPLAIN statement provides information about ...

  9. oracle 执行计划查看

    1)  sql command窗口里explain plan for select * from emp: 2) select * from table(dbms_xplan.display);

随机推荐

  1. OSW 快速安装部署

    关于在运行Oracle的环境下部署OSW具体好处不再多说,只需要知晓,在日常Oracle定位各类故障,osw的数据可以协助诊断问题.MOS很多文档也多处提到需要osw的监控数据. 一.前期资料准备 1 ...

  2. onclick事件触发 input type=“file” 上传文件

    添加按钮: <input type="button" name="button" value="浏览" onclick="j ...

  3. JavaScript面向对象中的继承

    1.1继承的基本概念 使用一个子类,继承另一个父类,那么子类可以自动拥有父类中的所有属性和方法,这个过程叫做继承. >>>继承的两方,发生在两个类之间. 实现继承的三种方式: 扩展O ...

  4. JS框架设计读书笔记之-选择器引擎02

    选择器引擎涉及相关概念 概念 以Sizzle的主函数声明为例,来说明引擎的相关概念. function Sizzle(selector, context, results, seed) { //... ...

  5. 模拟制作网易云音乐(AudioContext)

    记得好早前在慕课网上看到一款可视化音乐播放器,当前是觉得很是神奇,还能这么玩.由于当时刚刚转行不久,好多东西看得稀里糊涂不明白,于是趁着现在有时间又重新梳理了一遍,然后参照官网的API模拟做了一款网易 ...

  6. Display 和Visible 区别

    一.   web页面前台编码时经常用到display:none样式,平常使用时发现有几点特征需要注意   1.如果在样式文件或页面文件代码中直接用display:none对元素进行了隐藏,载入页面后, ...

  7. Spring框架学习之注解配置与AOP思想

         上篇我们介绍了Spring中有关高级依赖关系配置的内容,也可以调用任意方法的返回值作为属性注入的值,它解决了Spring配置文件的动态性不足的缺点.而本篇,我们将介绍Spring的又一大核心 ...

  8. JavaScript系列----作用域链和闭包

    1.作用域链 1.1.什么是作用域 谈起作用域链,我们就不得不从作用域开始谈起.因为所谓的作用域链就是由多个作用域组成的.那么, 什么是作用域呢? 1.1.1作用域是一个函数在执行时期的执行环境. 每 ...

  9. HTTPS 建立连接的详细过程

    HTTPS是在HTTP的基础上和ssl/tls证书结合起来的一种协议,保证了传输过程中的安全性,减少了被恶意劫持的可能.很好的解决了解决了http的三个缺点(被监听.被篡改.被伪装) 对称加密和非对称 ...

  10. 记录一次Session偶尔获取不到的解决过程

    导读 平台下某子系统有密码登录需求,初步考虑用Session,登录后设置Session[key]=value;Session中若某key对应的Session,即Session[key]为null则限制 ...