SQLServer常用的执行计算(数据访问操作符)

news/2024/7/10 4:04:12 标签: 数据库, 优化, 索引

1.SCAN及示例分析

SCAN依据表的不同,可以分为Table Scan,Cluster Index Scan,以及针对非聚集索引的Non-clustered Index Scan这三种操作。

聚集索引扫描(Cluster Index Scan)将表中所有数据行都存在于聚集索引的叶节点中,所以,聚集索引扫描相当于将整个数据都取出来了。

Index Scan发生在检索的数据都包含在已经定义好的索引之中,这样就不需要扫描整个表,只需要将索引中的数据取出便可,这样的索引被称为覆盖索引。由于Non-clustered Index所占用的空间比Cluster Index小,它的I/O成本会更低一些,所以查询优化器优先考虑使用Index Scan来查找这些数据。

在OLTP数据库中,SCAN操作被认为是性能的最大杀手,因为它不仅需要等待大量的磁盘I/O,还需要消耗很多内存来存储相关的数据。因此,在开发业务系统时应该注意,OLTP系统中应当避免大数据量的搜索,如果有一些数据集确实非常大,不妨使用分页算法。在数据库中可以使用存储过程来实现分页算法,以避免大量的数据扫描操作。


2.Seek及示例分析

查找(Seek)操作发生在索引上,他可以通过索引定位到具体的数据。依据索引的不同,可以区分为聚集索引查找和非聚集索引查找两种类型。

聚集索引查找发生在对聚集索引字段进行where条件过滤的情况下

非聚集索引查找发生在对非聚集索引字段进行where条件过滤的情况下。


3.BOOKMARK LOOKUP及示例分析

Key Lookup操作是Bookmark Lookup操作的一种。由于命名上的问题,姑且将Lookup称为标签查找吧,与seek操作区分开来。标签查找发生在使用了非聚集索引的语句中,用于查询不包含在当前索引的字段。例如SELECT TYPEID,NAME FROM BOOK WHERE TYPEID = 2,TYPEID是一个非聚集索引,NAME没有索引,此时通过Index Seek操作符找出索引数据后,还要通过标签查找NAME字段。


注意:在语句存在性能瓶颈的情况下,如果有扫描操作或者标签查找操作,都会被认为是有问题的,并且问题的产生原因是索引缺失,或者索引没有正确的覆盖到语句中。但是也还有一些别的可能,例如在索引自动断上应用了函数或者添加了计算,这些都将导致索引没有办法被正常使用。



http://www.niftyadmin.cn/n/1740388.html

相关文章

php yii gridview字符串截取,Yii2 GridView常见操作

下拉搜索日期格式化并实现日期可搜索根据参数进行是否显示链接可点击跳转显示图片html渲染自定义按钮设定宽度等样式自定义字段自定义行样式增加按钮调用js操作yii2 GridView 下拉搜索实现案例教程yii2 GridView 日期格式化并实现日期可搜索 案例是否显示某列案例type的值等于1…

Request.ServerVariables详解

ServerVariables是ASP.NET下Request对象的一个集合,里面包含了客户端与服务器的信息 ALL_HTTP 0, ALL_RAW 1, APPL_MD_PATH 2, APPL_PHYSICAL_PATH 3, AUTH_TYPE 4, AUTH_USER 5, A…

kafka php creat topic,用Python创建自定义的Kafka Topic

背景项目中需要创建分区(partitions)数不同的Topic。在server.properties中可以配置默认的Topic分区数量,但是不能在需要的时候任意改变。(使用Producer API会自动创建Topic)简单的Solution翻遍了Kafka-python的文档,没有发现kafka-python提供了类似clie…

php 输入框提示,javascript - 如何实现输入框提示功能?

给定一个输入框,一个搜索点击按钮,当输入框获得焦点时提示用户最近搜索内容,如何实现,有哪些方法。从哪些方面测试以保障其健壮性。回复内容:给定一个输入框,一个搜索点击按钮,当输入框获得焦点…

HTTP协议之媒体类型

摘录自ASP.NET WEB API设计第7页 媒体类型是英特网上客户端和服务器之间传递信息消息的格式。媒体类型的两部分标示组成,例如text/html。媒体类型有多种用户。有些媒体类型非常通用,例如,application/json(表示一组值或一组键值)或text/html…

iviewui php后端接口路径,SvnAdminV2.0

SVNAdmin 2.0 系统部署与使用手册该系统为使用PHP开发的Subversion(SVN)服务器端管理程序目前支持CentOS 8、CentOS7系统使用的开发语言及框架:Vue.jsiView UIPHPMedoo数据库框架ZeroMQ中间件一 系统部署(一)安装依赖yum install -y zip unzip wget #压缩与解压缩和…

atom php错误提示,atom插件频繁报错,怎么关闭错误信息提示?

一个暴力的方法是看下相关的报错信息,找到报错的插件的代码,然后将报错的代码注释之。比如,我遇到的这个linter-phpcs插件,在写php时总是报这个错,我忍了它很久:然后我百度了下,就看到楼主也在问…

checked和unchecked运算符

byte b byte.MaxValue; b; Console.WriteLine("b:"b); 这段代码运行后会显示b的值为0,因为byte的最大数是255,超过这个值会导致溢出,得到0。 为此C#提供了checked运算符来执行溢出检查,如果溢出则会抛出异常&#xff0…