导读:数据数优化查询一直是个比较热门的话题,小生在这方面也只能算是个入门生。今

天我们就讲下数据库包含列这个一项的作用及带来的优化效果

引用下MSDN里面的一段解释:

当查询中的所有列都作为键列或非键列包含在索引中时,带有包含性非键列的索引可以显

著提高查询性能。 这样可以实现性能提升,因为查询优化器可以在索引中找到所有列值;不

访问表或聚集索引数据,从而减少磁盘 I/O 操作

上面这一段什么意思呢?

意思就是说设置好包含列,能提高查询性能,减少IO输出。

这样说大家都觉得很抽象,下面我们举个例子来说明这个包含列的效果,

如何创建包含列索引?

1、 在对象资源管理器中,单击加号以便展开包含您要创建带有非键列的索引的表的数据库。

2、 单击加号以便展开“表”文件夹。

3、单击加号以便展开您要创建带有非键列的索引的表。

4、右键单击“索引”文件夹,指向“新建索引”,然后选择“非聚集索引…”。

5、 在“新建索引”对话框的“常规”页中,在“索引名称”框中输入新索引的名称。

6、 在“索引键列”选项卡下,单击“添加…”。

7、在“从 table_name 中选择列”对话框中,选中要添加到索引的一个或多个表列的复选框。

8、 单击“确定”。

9、 在“包含性列”选项卡下,单击“添加…”。

10、 在“从 table_name 中选择列”对话框中,选中要作为非键列添加到索引的一个或多个表列的复选框。

11、 单击“确定”。

12、 在“新建列”对话框中,单击“确定”。

举个例子来说明这个包含列的效果

    

      SQL:select Sex from User Where UserName='小三'

  

    我们来看下上面的语句 根据UserName来查询小三的性别,加入我们表中没有建任何索引,如果数据比较少的话 这个查询语句是没有任何问题的,但是当我们的用户量到达上千万时,这个查询可能就没当初那么快了,这个时候怎么提高查询效率呢?

 建立非聚集索引

 

第一个方法:给UserName建立非聚集索引,建立了索引之后数据库就能更快的找到这条数据所存在的位置。

 建立索引包含列

第二个方法:在给UserName建立非聚集索引的同时,建议包含列,包含Sex这一列,这样在快速定位UserName的同时又能很快定位出Sex的物理位置。包含列是对查询条件后的一种性能补充。

适用场景:该条查询用的非常频繁。select age from User Where UserName='小三'

比如在查询UserName的同时查询age非常多 就可以考虑给UserName建立非聚集索引的时候包含age这一列。

附上:建立包含列的SQL语句

1
2
3
4
5
6
7
8
9
USE AdventureWorks2012;
GO
-- Creates a nonclustered index on the Person.Address table with four included (nonkey) columns. 
-- index key column is PostalCode and the nonkey columns are
-- AddressLine1, AddressLine2, City, and StateProvinceID.
CREATE NONCLUSTERED INDEX IX_Address_PostalCode
ON Person.Address (PostalCode)
INCLUDE (AddressLine1, AddressLine2, City, StateProvinceID);
GO

Sql Server 性能优化之包含列的更多相关文章

  1. 【SQL Server性能优化】运用SQL Server的全文检索来提高模糊匹配的效率

    原文:[SQL Server性能优化]运用SQL Server的全文检索来提高模糊匹配的效率 今天去面试,这个公司的业务需要模糊查询数据,之前他们通过mongodb来存储数据,但他们说会有丢数据的问题 ...

  2. SQL Server 性能优化之——系统化方法提高性能

    SQL Server 性能优化之——系统化方法提高性能 阅读导航 1. 概述 2. 规范逻辑数据库设计 3. 使用高效索引设计 4. 使用高效的查询设计 5. 使用技术分析低性能 6. 总结 1. 概 ...

  3. SQL Server性能优化(6)查询语句建议

    1. 如果对数据不是工业级的访问(允许脏读),在select里添加 with(nolock) ID FROM Measure_heat WITH (nolock) 2. 限制结果集的数据量,如使用TO ...

  4. SQL SERVER性能优化综述

    SQL SERVER性能优化综述 一个系统的性能的提高,不单单是试运行或者维护阶段的性能调优的任务,也不单单是开发阶段的事情,而是在整个软件生命周期都需要注意,进行有效工作才能达到的.所以我希望按照软 ...

  5. SQL Server 性能优化之RML Utilities:快速入门(Quick Start)(1)

      SQL Server 性能优化之RML Utilities:快速入门(Quick Start)(1) 安装Quick Start工具 RML(Replay Markup Language)是MS ...

  6. SQL Server 性能优化(一)——简介

    原文:SQL Server 性能优化(一)--简介 一.性能优化的理由: 听起来有点多余,但是还是详细说一下: 1.节省成本:这里的成本不一定是钱,但是基本上可以变相认为是节省钱.性能上去了,本来要投 ...

  7. SQL Server性能优化与管理的艺术 附件下载地址

    首先感谢读者们对鄙人的支持,购买了<SQL Server性能优化与管理的艺术>,由于之前出版社的一些疏忽,附件没有上传成功,再次本人深表歉意. 请需要下载附件的读者从下面链接下载,谢谢: ...

  8. 【SQL Server性能优化】删除大量数据的方法比较

    原文:[SQL Server性能优化]删除大量数据的方法比较 如果你要删除表中的大量数据,这个大量一般是指删除大于10%的记录,那么如何删除,效率才会比较高呢? 而如何删除才会对系统的影响相对较小呢? ...

  9. SQL Server 性能优化详解

    故事开篇:你和你的团队经过不懈努力,终于使网站成功上线,刚开始时,注册用户较少,网站性能表现不错,但随着注册用户的增多,访问速度开始变慢,一些用户开始发来邮件表示抗议,事情变得越来越糟,为了留住用户, ...

随机推荐

  1. 通过Ajax post Json类型的数据到Controller

    View function postSimpleData() { $.ajax({ type: "POST", url: "/Service/SimpleData&quo ...

  2. 在 Excel 工作簿中定义决策表(Oracle Policy Modeling-Define decision tables in Excel workbooks)

    要在 Excel 中编写规则,您只需在表中编写规则,并使用 Oracle Policy Modeling 样式标识单元格中的信息类型, 以便这些规则可以编译并在 Oracle Determinatio ...

  3. FMS直播流发布时 Microphone Speex 编码设置注意事项

    1.为何要用 Speex?FP的默认音频编码是 NellyMoser,而FP10之后加入了 Speex.实际应用中,用默认的 NellyMoser 编码音频,会有个很大的问题,就是无法控制流码率浮动. ...

  4. FMS发布视频流H.264如何设置

    FMS这个话题由来已久,H.264这个编码格式也由来已久.FMS不叫FMS了,改叫AMS了.因为是Adobe. 今天就说说flash发布流媒体视频,以H.264编码出现的问题.在网上找,大把的关于as ...

  5. Oralce中SQL删除重复数据只保留一条(转)

    用SQL语句,删除掉重复项只保留一条 在几千条记录里,存在着些相同的记录,如何能用SQL语句,删除掉重复的呢 .查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断 select ...

  6. 百度ueditor 拖文件或world 里面复制粘贴图片到编辑中 上传到第三方问题

    我这边从world 里面复制粘贴图片到编辑器中,它自动给我上传了,但是我是用的第三方的要设置一个token值,我找了很久,也没有找到应该在哪里设置这个上传的参数,如果是点击图片上传,我知道在dialo ...

  7. 在DataGridView控件中加入ComboBox下拉列表框的实现

    在DataGridView控件中加入ComboBox下拉列表框的实现 转自:http://www.cnblogs.com/luqingfei/archive/2007/03/28/691372.htm ...

  8. C/C++ 错误处理

    has incomplete type and cannot be defined在头文件中添加该类型所在的文件eg:aggregate 'std::stringstream oss' has inc ...

  9. CodeForces 219D 树形DP

    D. Choosing Capital for Treeland time limit per test 3 seconds memory limit per test 256 megabytes i ...

  10. html 抽奖代码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...