博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
学习如何看懂SQL Server执行计划(一)——数据查询篇 (转)
阅读量:4958 次
发布时间:2019-06-12

本文共 958 字,大约阅读时间需要 3 分钟。

 转: https://www.cnblogs.com/taiyonghai/p/5594826.html

 

一、数据查询部分

1、 看到执行计划有两种方式,对sql语句按Ctrl+L,或按Ctrl+M打开显示执行计划窗口每次执行sql都会显示出相应的执行计划

2、 执行计划的图表是从右向左看的

3、 SQL Server有几种方式查找数据记录

[Table Scan] 表扫描(最慢),对表记录逐行进行检查

[Clustered Index Scan] 聚集索引扫描(较慢),按聚集索引对记录逐行进行检查

[Index Scan] 索引扫描(普通),根据索引滤出部分数据在进行逐行检查

[Index Seek] 索引查找(较快),根据索引定位记录所在位置再取出记录

[Clustered Index Seek] 聚集索引查找(最快),直接根据聚集索引获取记录

(如果有些sql执行很慢可以看一下执行计划是否包含太多“扫描”操作,如果有可以考虑为这些字段建立索引,建立索引切记不要再经常有更新操作的字段上建立,每次更新都会导致重建索引的操作,也会影响性能,0或1这种标识状态的字段因为大部分数据都是一样的建立索引也没有什么作用)

(索引就两种,1是聚集索引,2个非聚集索引,聚集索引每张表只能有一个,非聚集索引每张表可以有多个,主键Id就是典型的聚集索引,聚集索引是顺序排列的类似于字典查找拼音a、b、c……和字典文字内容顺序是相同的,非聚集索引与内容是非顺序排列的,类似字典偏旁查找时,同一个偏旁‘马’的汉字可能一个在第10页一个在第100页)

4、  

⑴没有主键的表查询[表扫描]

⑵有主键的表查询[聚集索引扫描]

⑶建立非聚集索引的表查询[索引扫描+书签查找]

书签查找:通过非聚集索引找到所求的行,但这个索引并不包含显示的列,因此还要额外去基本表中找到这些列,所以要进行键查找,如果基本表在堆中则Key Lookup会变成RID查找,这两个查找统称为书签查找。

⑷建立非聚集索引并把其他显示列加入索引中[索引查找]

⑸建立非聚集索引并把其他显示列加入索引中并把聚集索引列当作条件[聚集索引查找]

转载于:https://www.cnblogs.com/Impulse/articles/10433054.html

你可能感兴趣的文章
Developing for nRF52810(转载)
查看>>
java netty nio
查看>>
115 不同的路径Ⅱ
查看>>
POJ2104 K-th Number 主席树
查看>>
【转】Spring学习---为什么要用spring,springMVC
查看>>
idea激活
查看>>
wmi文章地址
查看>>
盒子的偏移量
查看>>
Spring3系列12- Spring AOP AspectJ
查看>>
JAVA异常与异常处理详解
查看>>
UML类图几种关系的总结
查看>>
链表中倒数第k个节点
查看>>
Frogger
查看>>
线程同步
查看>>
好久没写题解了= =这次是bzoj 1051
查看>>
box-shadow
查看>>
paramiko简单脚本
查看>>
Ubuntu系统OPENGL初体验
查看>>
Java异步调用模式
查看>>
idea tomcat上传图片,无法显示的问题解决
查看>>