SQL 使用总结四(关于索引)

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/mzl87/article/details/83550115

目录

介绍

索引的类型

何时考虑使用索引

何时应该避免使用索引

删除索引

SQL SERVER中的索引

1、简述

2、说明

3、例子


 

介绍

简单来说,索引就是指针,指向表里的数据。数据库里的索引和图书中的索引十分类似。当数据库没有索引是,它所进行的操作通常被称作全表扫描。

索引通常是和表分开保存的,其主要目的是提高数据库检索的性能。索引的创建和删除不会影响到数据本身,但会影响数据检索的速度。索引也会占据物理存储空间,而且可能回避表本身还大。因此在考虑数据库的存储空间时,需要考虑索引要占用的空间。

 

索引的类型

单字索引(对单个字段的索引),组合索引(对多个字段的索引。因为字段在索引里的次序对数据检索速度有很大的影响,一般最具有限制的值应该排在前面,从而得到更好的性能)和唯一索引(不允许表里有重复值),隐含索引(数据库服务器程序在创建对象时自动创建的)

 

何时考虑使用索引

1、主键、外键;一般来说,大多数用于表结合的字段都应该设置索引。

2、经常在ORDER BY 和GROUP BY里引用的字段也应该考虑设置索引。

3、具有大量唯一值的字段,或是在where子句里会返回很小部分记录的字段,都可以考虑设置索引。

 

何时应该避免使用索引

虽然使用索引的初衷是提高数据库的性能,但有时也要避免使用它们。下面是使用索引的方针。

  • 索引不应该用于小规模的表。因为查询索引会增加额外的查询时间。对于小规模的表, 让搜索引擎进行全表搜索,往往比先查询索引的速度更快。
  • 当字段用于WHERE子句作为过滤器会返回表里的大部分记录时,该字段就不合适设置索引。例如性别。
  • 经常会被批量更新的表可以具有索引,但批量操作的性能会由于索引而下降。对于经常会被加载或批量操作的表来说,可以在执行批量操作之前去除索引,在完成操作后再重新创建索引。这是因为当表里插入数据时,索引也会被更新,从而增加了额外的开销。
  • 不应该对包含大量NULL值的字段设置索引。字段中过多的NULL值会严重影响索引的运行效率。
  • 经常被操作的字段不应设置索引,因为对索引的维护变的很繁重。

 

删除索引

删除索引最常见的原因是尝试改善性能。记住,删除索引后,我们还可以重新创建它。有时候重建索引是为了减少碎片。在探索如何让数据库具有最佳性能时,调整索引是个必要的过程,其中可能包含创建索引、删除、最后在重新创建。

 

SQL SERVER中的索引

1、简述

在sql server 中索引分为聚簇索引和非聚簇索引。聚集索引是一种对磁盘上实际数据重新组织以按指定的一列或多列值排序。一个表只能建立一个聚集索引。非聚簇索引不重新组织表中的数据,而是对每一行存储索引列值并用一个指针指向数据所在的页面。一个表可以拥有多个非聚集索引,每个非聚集索引根据索引列的不同提供不同的排序顺序。

语法

CREATE [UNIQUE] [CLUSTERED| NONCLUSTERED ]
INDEX index_name ON { table | view } ( column [ ASC | DESC ] [ ,...n ] )
[with[PAD_INDEX][[,]FILLFACTOR=fillfactor]
[[,]IGNORE_DUP_KEY]
[[,]DROP_EXISTING]
[[,]STATISTICS_NORECOMPUTE]
[[,]SORT_IN_TEMPDB]
]
[ ON filegroup ]

2、说明

CREATE INDEX命令创建索引各参数说明如下:

UNIQUE:用于指定为表或视图创建唯一索引,即不允许存在索引值相同的两行。

CLUSTERED:用于指定创建的索引为聚集索引。

NONCLUSTERED:用于指定创建的索引为非聚集索引。

index_name:用于指定所创建的索引的名称。

table:用于指定创建索引的表的名称。

view:用于指定创建索引的视图的名称。

ASC|DESC:用于指定具体某个索引列的升序或降序排序方向。

Column:用于指定被索引的列。

PAD_INDEX:用于指定索引中间级中每个页(节点)上保持开放的空间。

FILLFACTOR = fillfactor:用于指定在创建索引时,每个索引页的数据占索引页大小的百分比,fillfactor的值为1到100。

IGNORE_DUP_KEY:用于控制当往包含于一个唯一聚集索引中的列中插入重复数据时SQL Server所作的反应。

DROP_EXISTING:用于指定应删除并重新创建已命名的先前存在的聚集索引或者非聚集索引。

STATISTICS_NORECOMPUTE:用于指定过期的索引统计不会自动重新计算。

SORT_IN_TEMPDB:用于指定创建索引时的中间排序结果将存储在 tempdb 数据库中。

ON filegroup:用于指定存放索引的文件组。

3、例子

--表bigdata创建一个名为idx_mobiel的非聚集索引,索引字段为mobiel

create index idx_mobiel
on bigdata(mobiel) 

--表bigdata创建一个名为idx_id的唯一聚集索引,索引字段为id

--要求成批插入数据时忽略重复值,不重新计算统计信息,填充因子为40

create unique clustered index idx_id
on bigdata(id) 
with pad_index,
fillfactor=40,
ignore_dup_key,
statistics_norecompute

猜你喜欢

转载自blog.csdn.net/mzl87/article/details/83550115