书签查找这个词可能对于很多开发人员比较陌生,很多人都遇到过,但是却没引起足够的重视以至于一直都忽略它的存在了。我们先来看一下书签查找的定义和重要性:

  书签查找定义

  当查询优化器使用非聚集索引进行查找时,如果序列所选择的列或查询条件中的列只部分包含在使用的非聚集索引和聚集索引中时,就需要一个查找(lookup)触发器来检索其他字段来满足请求。对一个有聚簇索引的表来说是一个键查找(keylookup),对一个堆表来说是一个RID查找(RIDlookup),这种查找即是——书签查找(bookmarklookup)。简单的说就是当你使用的sql查询条件和select返回的列没有完全包含在索引列中时就会发生书签查找。

  书签查找的重要性

  1.书签查找发生条件:只有在使用非聚集索引进行数据查找时才会产生书签查找,聚集索引查找、聚集索引扫描和表扫描不会发生书签查找。

  2.书签查找发生频率:书签查找发生频率非常高,甚至可以说大部分存储过程查询都会发生书签查找,我们知道一个表只能建立一个聚集索引,所以我们的查询更多的会使用非聚集索引,非聚集索引不可能覆盖所有的查询列,所以会经常性产生书签查找。

  3.书签查找的影响:导致索引失效的主要原因之一。书签查找根据索引的行定位器从表中读取数据,除了索引页面的逻辑读取外,还需要数据页面的逻辑读取,如果查询的结果返回数据量较大会导致大量的逻辑读或者索引失效,这也是为什么我们查看查询计划时有时明明在查询列上建立了索引,查询优化器却依然使用表扫描的原因。

  4.如何消除书签查找:

  1.使用聚集索引查找,聚集索引的叶子节点就是数据行本身,因此不存在书签查找

  2.聚集索引扫描、表扫描,说白了就是游标啥索引都不建直接全表扫描,肯定不会发生书签查找,不过效率吗。

  3.使用非聚集索引的键列包含所有查询或返回的列,这个不靠谱,非聚集struts索引最大键列数为16,最大索引键大小为900字节,就算你有勇气在16列上全部建立索引,那如果表的列数超过16列了你咋办,还有索引列长度之和不能超过900字节,所以不可能让非聚集索引包含所有列,而且索引涉及到得列越多维护索引的开销也就越大。

  4.使用include,嗯,这是个好东东,索引做到只能包含16列且不能超过900字节,include不受此限制,最多可以包含1023列怎么也够你用了,而且对spring长度也没有限制你可以随心所欲的包含nvarchar(max)这也的列,当然了text之流就不要考虑了

  下面小编想从性能角度进一步谈下书签查找,还有它们如何拉低你整个SQLServer性能。

  书签查找——反复循环

  如果你的非聚集索引不是个覆盖非聚集索引,SQLServer的查询优化器会引入书签查找。对于从非聚集索引你返回的每一行,SQLServer需要在聚集索引里或堆表里进行额外的查找操作。

  例如当你的的聚集索引包含3层,为了返回必要的信息,对于每一行,你需要3页额外的读取。因此,查询优化器再执行计划里选择书签查找操作,仅在有意义的时候发生——基于你查询的选择度。下图展示了有书签查找操作的执行计划。

  通常人们不会太关注书签查找,因为它们只执行几次。如果你的查询选择度太低,查询Hadoop优化器会用聚集索引扫描或表扫描运算符直接扫描整个表。但只在SQLServer重用缓存的执行计划,这个计划是有多次不同运行值,包含书签查找的(基于最初提供的输入值),因此这个情况很容易发生,书签查找反复执行。

  为了演示这个性能问题,接下来的查询我指定查询优化器使用特定的非聚集索引。查询本身返回80000行,因为对于每个查询执行,SQLServer需要进行书签查找80000次——反复执行。

  下图展示了查询执行后的实际执行计划。

  执行计划看起来非常恐怖(查询优化器甚至启用了并行计划!),因为书签查找运算符这里执行了80000次,查询本身产生了超过165000个逻辑读!(逻辑读个数可以从STATISTICIO里获取)。

  接下来向你展示下,当你有很多并行用户执行这个糟糕查询时,SQLServer会发生什么。我会使用ostress.exe(RML工具的一部分)来模拟100个并行用户的查询。

  在我的测试系统上花费了近15秒来完成100个并行查询。在此期间,CPU占用很高,因为SQLServer需要嵌套循环运算符来进行书签查找操作。嵌套循环操作当然很占CPU资源。

  现在让我们修改索引设计,为这个查询创建覆盖非聚集索引。有了非聚集索引,查询优化器不需要再执行计划里进行书签查找。一个非聚集索引查找就可以返回同样的结果:

  这次当我们再次用ostress.exe执行同个查询,我们看到Spark每个查询在5秒内完成。和我们刚才看到的15秒有很大的区别。这就是覆盖非聚集索引的威力:在我们查询里气门请求的数据都可以在非聚集索引里直接找到,因此书签查找就可以避免。

  小编结语:

  在这个文章里我向你展示了不好的书签查找会伤及性能。因此,对于重要的查询快速完成查询非常重要——而使用并行的书签查找的执行计划并不是好的选择。这里覆盖非聚集索引可以帮到你。下次设计索引时可以考虑下这个方法

SQL server的书签查找相关推荐

  1. 【译】索引进阶(六):SQL SERVER索引书签

    [译注:此文为翻译,由于本人水平所限,疏漏在所难免,欢迎探讨指正] 原文链接:传送门. 在之前的章节,我们把索引看做一组有序条目的集合,每行数据对应一个索引条目.我们解释了很多关于索引逻辑方面的内容, ...

  2. SQL Server临界点游戏——为什么非聚集索引被忽略!

    当我们进行SQL Server问题处理的时候,有时候会发现一个很有意思的现象:SQL Server完全忽略现有定义好的非聚集索引,直接使用表扫描来获取数据.我们来看看下面的表和索引定义: 1 CREA ...

  3. SQL Server 锁升级

    锁升级(Lock Escalations)是 SQL Server 使用的优化技术,用来控制在 SQL Server 锁管理里把持锁的数量.锁升级是将许多细粒度锁 ((如行或页) 锁)转换为表锁的过程 ...

  4. mysql 书签查找_SQL Server 索引 之 书签查找 第十一篇

    一.书签查找的概念 书签可以帮助SQL Server快速从非聚集索引条目导向到对应的行,其实这东西几句话我就能说明白. 如果表有聚集索引(区段结构),那么书签就是从非聚集索引找到聚集索引后,利用聚集索 ...

  5. SQL Server聚集索引的选择

    先声明文章非原创,摘自博客园:http://www.cnblogs.com/CareySon/archive/2012/03/06/2381582.html 简介    在SQL Server中,数据 ...

  6. SQL Server索引进阶第十篇:索引的内部结构

    索引设计是数据库设计中比较重要的一个环节,对数据库的性能其中至关重要的作用,但是索引的设计却又不是那么容易的事情,性能也不是那么轻易就获取到的,很多的技术人员因为不恰当的创建索引,最后使得其效果适得其 ...

  7. SQL Server 索引结构及其使用(二)(转)

    SQL Server 索引结构及其使用(二) 作者:freedk 一.深入浅出理解索引结构 改善SQL语句 很多人不知道SQL语句在SQL SERVER中是如何执行的,他们担心自己所写的SQL语句会被 ...

  8. SQL Server 索引结构及其使用(二)

    作者:freedk 一.深入浅出理解索引结构 改善SQL语句 很多人不知道SQL语句在SQL SERVER中是如何执行的,他们担心自己所写的SQL语句会被SQL SERVER误解.比如: select ...

  9. 一篇绝好的讲sql server索引的文章,值得收藏

    1.文章实验所使用的表结构 CREATE TABLE [dbo].[TGongwen] ( --TGongwen是红头文件表名 [Gid] [int] IDENTITY (1, 1) NOT NULL ...

最新文章

  1. Python之tkinter:动态演示调用python库的tkinter带你进入GUI世界(Canvas)
  2. (2.13)Mysql之SQL基础——触发器
  3. 【机器学习】深入理解CatBoost
  4. Settype COM_TA_MANUFAC - mapping between ERP Equipment and CRM Individual Object
  5. C++编程连接string字符串和int数字的好方法
  6. 微博如何发订阅消息_微信订阅号或将大变天,微博8年前就这么干了...
  7. leetcode面试题 17.08. 马戏团人塔(二分法)
  8. 有关Botton的用法(二)
  9. oracle 循环修改数据库,oracle对一个表的多行数据进行修改,SQL批量修改
  10. iscsi:IO操作流程(一)
  11. sql 操作常用操作语句 新增、修改字段等
  12. MATLAB textscan之模式匹配用法
  13. 微信语音麦克风静音_微信中打电话静音是我被静音还是对方被静音,具体这个静音是什么意思...
  14. 用计算机教学体育,体育教学中计算机的应用
  15. 苹果公司独有的“产品包装艺术”
  16. 我的世界1.12.2java下载_我的世界Minecraft Java版1.12.2 pre2 宣布
  17. idea合并分支代码怎么操作呢?
  18. 高等数学(第七版)同济大学 总习题九(后10题) 个人解答
  19. Linux新加硬盘挂载
  20. jsx中文是什么牌子口红_cl口红是什么牌子 cl口红中文名字

热门文章

  1. OpenDDS开发人员指南中文版3.23(9)DCPS信息库DCPSInfoRepo
  2. 【patsubst函数】
  3. CodeCombat代码全记录(Python学习利器)--边地森林(第二章)代码6
  4. 如何在VB中添加SysInfo控件
  5. DSP+FPGA的前景及应用调研
  6. (八)hystrix-服务熔断和降级
  7. Zynq学习_____以太网三部曲(二)LWip_初始化过程
  8. 【shell】shell脚本实战-while循环语句
  9. Linux | 编译器gcc/g++的使用【动静态库的认识】
  10. PHPm-code1