码迷,mamicode.com
首页 > 数据库 > 详细

sql索引

时间:2020-01-10 17:19:27      阅读:73      评论:0      收藏:0      [点我收藏+]

标签:应用程序   创建索引   根据   频繁   sel   删除   相同   建立   自动   

在SQL Server中,一个表只能创建一个聚集索引,但可以将多个非聚集索引。设置某列为主键,该列就默认为聚集索引。

  1. 频繁搜索的列。
  2. 经常用于查询选择的列。
  3. 经常排序、分组的列。
  4. 经常用于连接的列(主键/外键)。

不要使用下面的列创建索引。

  1. 仅包含几个不同值得列。
  2. 表中仅包含几行,为小型表创建索引可能不太划算,因为SQL Server在索引中搜索数据所花的时间比在表中逐行搜索所花的时间更长。
  3. 在SQL 语句中,特别是在select语句中正确使用索引可以大大提高查询速度,保证应用程序的运行性能。提供几条经验,仅供大家参考:
    1. 查询时尽量减少使用“星号”返回全部列,不要返回不需要的列。
    2. 索引应该尽量小,在字节数小的列上建立索引。
    3. where 字句中有多个条件表达式时,包含索引列的表达式应置于其他表达式之前。
    4. 避免在order by 字句中使用表达式。
    5. 根据业务数据发生频率,定期重新生成或重新组织索引,进行碎片整理。(因为在SQL server中,索引数据是由系统自动维护的,在增加、删除和修改数据后,索引数据可能会更新。随着长期频繁的数据更新,索引数据会分散在磁盘的不同位置,形成碎片,由此造成查询速度越来越慢,因此,根据数据更新的频率,定期删除原有索引,重新创建相同的索引,让索引存放在连续的空间中,以此删除碎片,可提高查询速度。)

sql索引

标签:应用程序   创建索引   根据   频繁   sel   删除   相同   建立   自动   

原文地址:https://www.cnblogs.com/zzZ1911/p/12177079.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!