位置: 编程技术 - 正文

解析SQL Server聚焦移除(Bookmark Lookup、RID Lookup、Key Lookup)(解析sql语句)

编辑:rootadmin

推荐整理分享解析SQL Server聚焦移除(Bookmark Lookup、RID Lookup、Key Lookup)(解析sql语句),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sql server常用的聚合函数,sql解析框架,sql解析器 java,解析sql语句,sql解析器,解析sql语句,sql解析原理,sql解析器,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

前面几节都是讲的基础内容,本节我们讲讲索引性能优化,当对大数据进行处理时首先想到的就是索引,一旦遇到这样的问题则手忙脚乱,各种查资料,为何平常不扎实基本功呢,我们由浅入深,简短的内容,深入的理解,而非一上来就把问题给框死,立马给出解决方案,抛出问题,再到解决问题,你GET了没有。

Bookmark Lookup、RID Lookup、Key Lookup定义

一说到这三者,如果对索引研究不深的童鞋估计是懵逼的,什么玩意,我们姑且将上面三者翻译为:标签查找、行ID查找、键查找。标签查找和键查找是一个意思,在SQL 之前叫Key Lookup。怎么解释,如何定义呢?首先我们不看定义,直接看下面一步一步解析,如果你实在忍不住,请看园友【永红】的见解,解释还是非常到位。我们简短的说明下此三者概念。

在查询中,我们对返回的列在查询条件上若建立了非聚集索引,此时将可能尝试使用非聚集索引查找,如果返回的列没有创建非聚集索引,此时会返回到数据页中去获取这些列的数据,即使表中存在聚集索引或者没有,都会返回到表中或者聚集索引中去获取数据。对于以上场景描述,如果表没有创建聚集索引则称为Bookmar Lookup,如果表中没有聚集索引但是存在非聚集索引我们称为RID Lookup。看到这里我们就会想法操作如此耗时,还要返回到基表中去获取数据,所以才有了我们本节来移除以上三者来提高查询性能。接下来我们一起来看看。

抛出Bookmark Lookup、RID Lookup、Key Lookup问题

我们首先创建如下表

接着进行查询

这个不用多讲,没添加任何索引,执行查询计划是全表扫描。接下来我们创建在orderid上创建聚集索引如下:

CREATE CLUSTERED INDEX idx_cls_orderid ON Sales.Orders(orderid)

我们再执行上述查询

此时我们创建了聚集索引,所以此时查询走聚集索引,到这里我们看到情况由全表扫描转换成了索引扫描。我们在查询时一直是带了查询条件的,而对查询条件我们未作任何操作,如果我们此时在查询条件上创建了索引,此时查询的性能又会得到一点改善。我们开始对查询条件创建一个非聚集索引。

CREATE NONCLUSTERED INDEX idx_nc_shipcity ON Sales.Orders(shipcity)

我们再接着执行查询

我们观察到对查询条件创建了非聚集索引,查询计划会使用非聚集索引查找返回结果,但是对于shipaddress, shipcity, shipregion并不是索引的一部分,此时查询引擎会返回到基表中得到这些数据再返回。这种行为就叫做Bookmark Lookup或者Key Lookup。下面我们就如本文标题一样问题出现来解决问题,移除Bookmark Lookup或者Key Lookup。我们尝试用两种不同的方法来解决。

解决Bookmark Lookup、RID Lookup、Key Lookup问题

创建非聚集索引覆盖索引

我们对查询条件以及检索列创建非聚集索引。

CREATE NONCLUSTERED INDEX idx_all_cover ON Sales.Orders(shipaddress,orderid,shipcity,shipregion)

此时我们对检索列创建了非聚集索引,此时将不会再到数据页中获取数据,而是从索引中直接返回,所以到这里我们算是移除了Key Lookup。但是此时触发另外一个问题,执行查询计划走的却是索引扫描,索引到底是什么呢?我们打个比方,一个索引相当于是数据库中一个本书开始的索引,我们需要快速从书中查找到我们所需要的数据,这个时候书就是我们所说的表。索引扫描意味着要读取表中的所有行,然后返回满足条件的所有数据,当执行索引扫描时,所有行上叶子节点上的所有都会被扫描,这也就意味着索引上的所有行都会被检索一遍而不是直接检索表,和表扫描对比的话,表扫描是直接读取表中数据,所以表扫描和索引扫描还是有一点点不同,而索引查找则是依赖于索引页数据来定位满足条件的所有行,索引查找仅仅只影响满足条件以及页上包含这些满足条件的行,所以说索引查找更加高效。

解析SQL Server聚焦移除(Bookmark Lookup、RID Lookup、Key Lookup)(解析sql语句)

上述我们稍微讲解了下索引扫描和索引查找,而上述的问题是我们创建了非聚集索引,但是结果执行的查询计划是索引扫描,很是纳闷,对于刚学索引小白的我来说,不知该如何是好,以为是缓存的缘故,清除各种缓存均不好使。于是开始胡思乱想是不是检索列中数据有为NULL引起的,是不是检索列数据重复引起的,尝试了无数次,最终发现某一次居然好使。如下

此时若我们将查询条件进行如下修改。

到这里我们应该发现了,唯一的区别在于我们创建非聚集索引时的顺序和查询条件不同就会导致索引扫描和索引查找的转换,那么到底什么时候才会执行索引查找呢?我们可以进行如下一般性总结:

索引查找的一般性结论:如果条件中包含WHERE或者ON的话,查询条件必须是位于索引集合列中首位,此时索引查找将会被使用。

此时我们穿插一点内容,上述我们创建了覆盖索引,我们来比较下覆盖索引和默认情况下聚集索引查找的性能开销。

覆盖索引与默认聚集索引性能开销比较

从上可知,覆盖索引的开销要比默认主键聚集索引性能开销要好一点,同时我们可以看看如下二者IO代价。

通过上述覆盖索引与默认聚集索引的对比,我们能够有效的减少IO,这一点也是非常明确的,当然下面的INCLUDE索引对比也是另外一种好的方案。

创建INCLUDE非聚集索引

至此我们用两种方式来移除了Bookmark Lookup、RID Lookup、Key Lookup,通过使用索引和覆盖索引。

既然有如上两种方式,我们应该有所取舍,二者谁的性能更好呢?我们接下来比较上述二者的开销差异。

比较移除Bookmark Lookup等两种方式差异

我们从上所知,二者开销一样,并未有什么区别,当然相信我们更倾向于的是将第二种方式作为解决方案。到这里算是基本结束了,但是还有一个小问题,我们在之前已经创建了orderid的聚集索引,后面在解决方案中我们也添加了orderid的非聚集索引,难道非得添加吗,我们去掉试试看。

去除orderid比较二者开销差异:

由上知,非聚集索引列不需要包含创建了聚集索引的列,那么事实到底是怎样的呢?

结论:其实对于任何非聚集索引列都不需要包含创建了聚集索引的列,因为创建聚集索引的列是非聚集索引集合列的一部分,也就是说只要一个表上的列创建了聚集索引,那么非聚集索引集合列就包含了这个聚集索引。

总结

本节我们比较详细就问题的抛出到问题的解决,从而来提高查询性能,好了,到此结束,我们下节再会。简短的内容,深入的理解

标签: 解析sql语句

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

上一篇:高效mongodb的php分页类(不使用skip)(mongodb 教程)

下一篇:SqlSever 注释符 单行注释与多行注释(sqlsever注释符号)

  • 牛奶的增值税税率
  • 土地使用税的纳税时间
  • 两处以上取得工资如何交社保
  • 在建工程和预付款项调整
  • 交强险可以打折扣吗
  • 企业收到银行收款通知
  • 发票报销的条件是什么?
  • 公司向个人租房子怎么做账
  • 固定资产期初余额在哪里录入
  • 打官司失败了要赔偿原告诉讼费吗?
  • 自建厂房可以不办理房产证吗
  • 经纪人佣金计入什么科目
  • 应付账款不付处理分录如何写?
  • 设备的配件怎么做分录
  • 该期已经申报此税种且数据已提交,不能预约扣款
  • 出口退税综合服务平台电话
  • 统一员工行为规范
  • 商品流通企业代表企业
  • 固定资产产权转移
  • 支付罚款的支出计入什么科目
  • 基金赎回手续费怎么计算
  • 支票大写金额书写转换
  • 公司钱被取走怎么处理
  • 上年度开具的发票存根联损毁应该怎么做
  • 工信部推出一键解绑怎么用
  • 不缴或少缴应纳税款的行为属于
  • 分公司特征表述正确的是
  • 广告业进项都能开什么票
  • 羊毛衫变形了还能变回来吗
  • 应付债券包括
  • PHP:spl_autoload_extensions()的用法_spl函数
  • 账务处理程序有什么
  • 辉柏嘉彩铅一共多少色
  • 2022年增值税免税政策
  • 企业年金缴纳标准400什么意思啊
  • 低值易耗品现在还用吗
  • php7.0新特性
  • thinkphp怎么运行
  • 视同销售的行为
  • 资本化的研发费用计入什么科目
  • wordpress静态分离
  • vue-plugin-hiprint vue hiprint vue使用hiprint打印控件VUE HiPrint HiPrint简单使用
  • element_at
  • 投资收益的核算依据
  • 垃圾处置费的收费标准
  • 合同资产要结转增值税吗
  • Linux常用命令与vim
  • 长期股权投资减值准备是什么科目
  • 怎么看企业用哪种软件
  • 触发器失败是什么意思
  • 体检费用需要缴哪些费用
  • 残保金提取是什么意思
  • 利息收入交税不
  • 贷款减值准备是什么意思
  • 贴现费用分录
  • 预算会计年末如何结账
  • 小微企业如何自己开发票
  • 公司投资款怎么算
  • 固定资产折旧如何计提
  • 先进先出法实际成本跟成本不一样吗
  • 软件折旧从什么时候算
  • 零配件供应是什么意思
  • mysql数据库简单介绍
  • mysql2002解决办法
  • Linux系统配置IP
  • 电脑找不到关机选项了怎么关机
  • linux groupdel命令详解
  • jquery设置鼠标样式
  • android中文文档
  • 收集linux日志
  • jquery中判断某个类是否存在的方法
  • os模块 python
  • JavaScript中的方法名不区分大小写
  • js 队列
  • 天津2023防暑降温费标准文件
  • 陕西宝鸡国税人才招聘
  • 交了增值税还用交税吗
  • 单位名称变更后发票还能用吗
  • 普宁市离揭阳市有多远
  • 消费税记不记入成本
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设