MSSQL聚集索引扫描 Scan Direction的两种方式--FORWARD 和 BACKWARD

0    71    1

Tags:

👉 本文共约3242个字,系统预计阅读时间或需13分钟。

最近发现一个分页查询存储过程中的的一个SQL语句,当聚集索引列的排序方式不同的时候,效率差别达到数十倍,让我感到非常吃惊
由此引发出来分页查询的情况下对大表做Clustered Scan的时候,
不同情况下会选择FORWARD 或者 BACKWARD差别,以及建立聚集索引时,选择索引列的排序方式的一些思考
废话不多,上代码
先建立一张测试表,在Col1上建立聚集索引,写入100W条数据

先直观地看一下聚集索引扫描时候的FORWARD 和 BACKWARD

 BACKWARD

  执行如下分页查询,当按照Col4符合2017-7-18和2017-7-23,并且Col1 倒序排序的时候
  从执行计划看,Clustered Index Scan的Scan Direction的方式是BACKWARD

  MSSQL聚集索引扫描 Scan Direction的两种方式--FORWARD 和 BACKWARD

MSSQL聚集索引扫描 Scan Direction的两种方式--FORWARD 和 BACKWARD

 

FORWARD

  执行如下分页查询,当按照Col4符合2017-7-18和2017-7-23,并且Col1 正序排序的时候
  从执行计划看,Clustered Index Scan的Scan Direction的方式是FORWARD

MSSQL聚集索引扫描 Scan Direction的两种方式--FORWARD 和 BACKWARD

MSSQL聚集索引扫描 Scan Direction的两种方式--FORWARD 和 BACKWARD

  查询条件一样,分页情况下,排序方式不一样,性能上有么有差别?肯定有,太明显了,如果没有,本文也就没有什么意义了
  如图是上述两种查询方式在我本机的测试结果,同样是前100条数据,因为排序方式不同,其代价也是不同的
  逻辑读,一个是2327,一个是9978次,差别不小吧,在实际场景中,这个差别是非常非常大的,大到足以超乎你想想

对FORWARD和BACKWARD有一个直观的感受之后,来说说这两者的区别

  如果了解B树索引结构的话,应该知道聚集索引是以类似于B树结构的方式来组织的,既然是B树结构,
  那么下面这个图就不难理解了,
  在索引列按照某事方式排序的情况下,比如

  下面这张图分别是FORWARD和BACKWARD两种Scan direction的实现方式

 MSSQL聚集索引扫描 Scan Direction的两种方式--FORWARD 和 BACKWARD

                FORWARD

MSSQL聚集索引扫描 Scan Direction的两种方式--FORWARD 和 BACKWARD

                    BACKWARD

本人提供Oracle(OCP、OCM)、MySQL(OCP)、PostgreSQL(PGCA、PGCE、PGCM)等数据库的培训和考证业务,私聊QQ646634621或微信db_bao,谢谢!
MSSQL聚集索引扫描 Scan Direction的两种方式--FORWARD 和 BACKWARD后续精彩内容已被小麦苗无情隐藏,请输入验证码解锁本站所有文章
验证码:
请关注本站微信公众号,回复“小麦苗博客”,获取验证码。在微信里搜索“DB宝”或者“www_xmmup_com”或者微信扫描右侧二维码都可以关注本站微信公众号。

标签:

Avatar photo

小麦苗

学习或考证,均可联系麦老师,请加微信db_bao或QQ646634621

您可能还喜欢...

发表回复

嘿,我是小麦,需要帮助随时找我哦
  • 18509239930
  • 个人微信

  • 麦老师QQ聊天
  • 个人邮箱
  • 点击加入QQ群
  • 个人微店

  • 回到顶部