SQL及其使用(3)
3.3、索引
SQL索引:
SQL索引有两种,聚集索引和非聚集索引,索引主要目的是提高了SQL Server系统的性能,加快数据的查询速度与减少系统的响应时间
1,概念: 数据库索引是对数据表中一个或多个列的值进行排序的结构,就像一本书的目录一样,索引提供了在行中快速查询特定行的能力.
2,优缺点:
2.1优点: 1,大大加快搜索数据的速度,这是引入索引的主要原因.
2,创建唯一性索引,保证数据库表中每一行数据的唯一性.
3,加速表与表之间的连接,特别是在实现数据的参考完整性方面特别有意义.
4,在使用分组和排序子句进行数据检索时,同样可以减少其使用时间.
2,2缺点: 1,索引需要占用物理空间,聚集索引占的空间更大.
2,创建索引和维护索引需要耗费时间,这种时间会随着数据量的增加而增加.
3,当向一个包含索引的列的数据表中添加或者修改记录时,SQL server 会修改和维护相应的索引,这样增加系统的额外开销,降低处理速度。
3,索引的分类:
1,按存储结构可分为:
a,聚集索引:指物理存储顺序与索引顺序完全相同,它由上下两层组成,上层为索引页,下层为数据页,只有一种排序方式,因此每个表中只能创建一个聚集索引。
b,非聚集索引:指存储的数据顺序一般和表的物理数据的存储结构不同。
测试:
对于5百万条简单的数据,创建索引之前的运行时间如下:
创建索引之后
搜索时,使用非索引属性: