sql索引
Posted zzz1911
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql索引相关的知识,希望对你有一定的参考价值。
在SQL Server中,一个表只能创建一个聚集索引,但可以将多个非聚集索引。设置某列为主键,该列就默认为聚集索引。
- 频繁搜索的列。
- 经常用于查询选择的列。
- 经常排序、分组的列。
- 经常用于连接的列(主键/外键)。
不要使用下面的列创建索引。
- 仅包含几个不同值得列。
- 表中仅包含几行,为小型表创建索引可能不太划算,因为SQL Server在索引中搜索数据所花的时间比在表中逐行搜索所花的时间更长。
- 在SQL 语句中,特别是在select语句中正确使用索引可以大大提高查询速度,保证应用程序的运行性能。提供几条经验,仅供大家参考:
- 查询时尽量减少使用“星号”返回全部列,不要返回不需要的列。
- 索引应该尽量小,在字节数小的列上建立索引。
- where 字句中有多个条件表达式时,包含索引列的表达式应置于其他表达式之前。
- 避免在order by 字句中使用表达式。
- 根据业务数据发生频率,定期重新生成或重新组织索引,进行碎片整理。(因为在SQL server中,索引数据是由系统自动维护的,在增加、删除和修改数据后,索引数据可能会更新。随着长期频繁的数据更新,索引数据会分散在磁盘的不同位置,形成碎片,由此造成查询速度越来越慢,因此,根据数据更新的频率,定期删除原有索引,重新创建相同的索引,让索引存放在连续的空间中,以此删除碎片,可提高查询速度。)
以上是关于sql索引的主要内容,如果未能解决你的问题,请参考以下文章