SQL SERVER书签查找
SQL SERVER书签查找
SQL SERVER书签查找一、SQL SERVER书签查找定义
当查询优化器使用非聚集索引进行查找时,如果所选择的列或查询条件中的列只部分包含在使用的非聚集索引和聚集索引中时,就需要一个查找(lookup)来检索其他字段来满足请求。对一个有聚簇索引的表来说是一个键查找(key lookup),对一个堆表来说是一个RID查找(RID lookup),这种查找即是——书签查找(bookmark lookup)。
简单的说就是当你使用的sql查询条件和select返回的列没有完全包含在索引列中时就会发生书签查找。
二、SQL SERVER书签查找实例
1、表结构
其中 有一个 聚簇索引 PK_UserID 和一个 非聚簇索引IX_UserName。
2、执行如下SQL 语句
select UserName,Gender from dbo.UserInfo where UserName='userN600'
按上面的 SQL 产生执行计划 可以看出, 会产生一个书签查找(Key Lookup),如下图
2、如果需要增加逻辑读操作或者开销较大的物理读操作使书签查找的数据检索操作开销相当大,这个开销因素是非聚集索引更适合于返回较小的数据行数的原因。随着查询检索的行数增加,书签查找的开销将变得无法接受。
3、为了理解书签查找随着检索行数增加而使feu聚集索引无效,下面来看一个实例:
在Person表的ID(以1递增)上建索引,我们来看看下面两个查询的执行计划
(1)、返回100条
(2)、返回300条
我们看到,当要求返回300条数据的时候,SQL Server就不在使用Id列上的非聚集索引,而是直接进行表扫描了。因为SQL Server认为执行300次书签查找还不如直接对一张1万条记录的表进行全表扫描。
4、由上面的实例可以得出结论,返回大的结果集将增加书签查找的开销,甚至低于表扫描。因此在返回较大结果集的情况下,必须考虑避免书签查找的可能性。
四、避免书签查找的方法
1、使用聚集索引
对于聚集索引,索引的叶子页面和表的数据页面相同。因此,当读取聚集索引键列的值时,数据引擎可以读取其他列的值而不需要任何导航。例如前面的区间数据查询的操作,SQL Server通过B树结构进行查找是非常快速的。
把非聚集索引转换为一个聚集索引说起来很简单。但是,这个例子和大部分可能遇到的情况下,这不可能做到,因为表已经有了一个聚集索引。这个表的聚集索引恰好是主键。必须卸载掉所有的外键约束,卸载并且重建为一个非聚集索引。这不仅要考虑所涉及的工作,还可能严重地影响依赖于现有聚集索引的其他查询。
2、使用覆盖索引
例如
select id,name from persontenthousand where id <100
我们可以在 id,name上面建个组合索引,这样,由于非聚集索引上已经有了需要查询的Id和Name列的数据,所以不在需要书签查找定位到基本表。
3、使用索引连接
如果覆盖索引变得非常宽,那么可能要考虑索引连接技术。索引连接技术使用两个或更多索引之间的一个索引交叉来完全覆盖一个查询。因为索引连接技术需要访问多余一个索引,它必须在所有索引连接中使用的索引上执行逻辑读。因此,索引连接需要比覆盖索引更高的逻辑读数量。但是,因为索引连接所用的多个窄索引能够比宽的覆盖索引服务更多的查询。所以索引连接也可以作为避免书签查找的一种技术来考虑。
上面的例子我们创建了两个非聚集索引,一个在 Id列,一个在Name列。但是我们的查询需要同时返回Id列和Name列。而这两个非聚集索引都不完全包含要返回列。这个时候,哈希匹配目的就是通过定位到索引,而不用定位到基本表就能够获得我们所需要的全部数据,这样索引连接就避免了书签查找。
- sqlserver数据库实时同步(SQL Server实时同步更新远程数据库遇到的问题小结)
- sqlserver基础数据类型(SQL Server中T-SQL 数据类型转换详解)
- python实现sql脚本规范(基于Python的SQL Server数据库实现对象同步轻量级)
- sql server2012表的数据删除(SQL Server删除表及删除表中数据的方法)
- sql server中dense_rank和row_number的区别
- sqlserver字段增加删减(关于SQL Server中bit类型字段增删查改的一些事)
- sql数据库安装概要(详解将DataGrip连接到MS SQL Server的方法)
- sqlserver数据库如何分页(SQL server分页的4种方法示例很全面)
- sqlserver百分比数据查询时间(SQL Server统计信息更新时采样百分比对数据预估准确性的影响详解)
- SQL SERVER中根据身份证号获取出生日期
- SQL Server作业
- sql执行原理详解(Sql server中内部函数fn_PhysLocFormatter存在解析错误详解)
- sql server中有哪几种锁定模式(SQL Server三种锁定模式的知识讲解)
- 查看SQL SERVER指定数据库中所有的触发器
- SQL SERVER存储过程调试
- sql server怎么导出数据库(sqlserver复制数据库的方法步骤图文)
- 素人恋爱综艺火药味十足 男生为赢得芳心集体扯头花,真是出好戏(素人恋爱综艺火药味十足)
- 《囧妈》为何受抵制 春节七部影片撤档背后的责任与博弈(囧妈为何受抵制)
- 提醒 2019年起河南驾考要开设科目五 官方回应来了(2019年起河南驾考要开设科目五)
- 省 市书法家协会 送万福进万家 活动走进禹州美丽乡村(省市书法家协会)
- 点赞 禹州苌庄正式撤乡建镇 未来发展不可估量(禹州苌庄正式撤乡建镇)
- 它荣获 中国生态魅力镇 称号 就在咱们禹州,一起来看看(中国生态魅力镇)
热门推荐
- mysql定时任务
- vue三种判断条件(Vue中插槽和过滤器的深入讲解)
- css弹性布局设置每行显示指定个数(CSS实现多行多列的布局的实例代码)
- mysql在centos7中如何安装(阿里云centos7安装mysql8.0.22的详细教程)
- sqlserver管理工具远程连接(MSSQLSERVER不同版本设置开启远程连接sa配置)
- navicat中如何使用sql语句(Navicat Premium操作MySQL数据库执行sql语句)
- 云服务器自建服务器成本比较(云服务器与服务器租用之间的区别在哪里?)
- react组件分析(react-diagram 序列化Json解读案例分析)
- vue 为什么要使用key(详解vue中v-for的key唯一性)
- 云虚拟主机缺点(云虚拟主机未来会怎么发展?)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9