关于聚集索引的问题
2008-11-28 17:12
302 查看
聚集索引确定表中数据的物理顺序。聚集索引类似于电话簿,后者按姓氏排列数据。由于聚集索引规定数据在表中的物理存储顺序,因此一个表只能包含一个聚集索引。但该索引可以包含多个列(组合索引),就像电话簿按姓氏和名字进行组织一样。
聚集索引就是指索引项的顺序与表中记录的物理顺序一致的索引组织,
建立该索引后,如果对表更新,可能导致表中记录物理顺序的变更,因此对于经常更新的关系表,通常不建议使用聚集索引。
聚集索引对于那些经常要搜索范围值的列特别有效。使用聚集索引找到包含第一个值的行后,便可以确保包含后续索引值的行在物理相邻。例如,如果应用程序执行
的一个查询经常检索某一日期范围内的记录,则使用聚集索引可以迅速找到包含开始日期的行,然后检索表中所有相邻的行,直到到达结束日期。这样有助于提高此
类查询的性能。同样,如果对从表中检索的数据进行排序时经常要用到某一列,则可以将该表在该列上聚集(物理排序),避免每次查询该列时都进行排序,从而节
省成本。
非聚集索引与课本中的索引类似。数据存储在一个地方,索引存储在另一个地方,索引带有指针指向数据的存储位置。索引中的项目按索引键值的顺序存储,而表中的信息按另一种顺序存储(这可以由聚集索引规定)。如果在表中未创建聚集索引,则无法保证这些行具有任何特定的顺序。
有聚集索引的ID,里面的TOP语句影响不到外层的取值(你可以从执行计划看到有差异).
SQL code
use tempdb
go
create table t1(id int not null)
go
create clustered index ix_t1_id on t1(id)
go
insert t1 select 3
union all select 2
union all select 5
union all select 1
union all select 4
union all select 7
union all select 6
go
select max(id) from(select top 1 id from t1)a
select max(id) from(select top 3 id from t1)a
go
drop index ix_t1_id on t1
go
select max(id) from(select top 1 id from t1)a
select max(id) from(select top 3 id from t1)a
go
drop table t1
go
/**
1
**/
/**
7
**/
/**
1
**/
/**
3
**/
由上面的例子可以看出TOP语句影响不到外面的取值,所得到的MAX()都是所有值中最大的 “7”,当然TOP 1除外。
聚集索引就是指索引项的顺序与表中记录的物理顺序一致的索引组织,
建立该索引后,如果对表更新,可能导致表中记录物理顺序的变更,因此对于经常更新的关系表,通常不建议使用聚集索引。
聚集索引对于那些经常要搜索范围值的列特别有效。使用聚集索引找到包含第一个值的行后,便可以确保包含后续索引值的行在物理相邻。例如,如果应用程序执行
的一个查询经常检索某一日期范围内的记录,则使用聚集索引可以迅速找到包含开始日期的行,然后检索表中所有相邻的行,直到到达结束日期。这样有助于提高此
类查询的性能。同样,如果对从表中检索的数据进行排序时经常要用到某一列,则可以将该表在该列上聚集(物理排序),避免每次查询该列时都进行排序,从而节
省成本。
非聚集索引与课本中的索引类似。数据存储在一个地方,索引存储在另一个地方,索引带有指针指向数据的存储位置。索引中的项目按索引键值的顺序存储,而表中的信息按另一种顺序存储(这可以由聚集索引规定)。如果在表中未创建聚集索引,则无法保证这些行具有任何特定的顺序。
有聚集索引的ID,里面的TOP语句影响不到外层的取值(你可以从执行计划看到有差异).
SQL code
use tempdb
go
create table t1(id int not null)
go
create clustered index ix_t1_id on t1(id)
go
insert t1 select 3
union all select 2
union all select 5
union all select 1
union all select 4
union all select 7
union all select 6
go
select max(id) from(select top 1 id from t1)a
select max(id) from(select top 3 id from t1)a
go
drop index ix_t1_id on t1
go
select max(id) from(select top 1 id from t1)a
select max(id) from(select top 3 id from t1)a
go
drop table t1
go
/**
1
**/
/**
7
**/
/**
1
**/
/**
3
**/
由上面的例子可以看出TOP语句影响不到外面的取值,所得到的MAX()都是所有值中最大的 “7”,当然TOP 1除外。
相关文章推荐
- 关于数据库写入慢的问题autocommit,索引等对Innodb写入速度的影响
- 关于数据库全文索引的问题
- 关于聚集索引和非聚集索引
- 关于order by与索引的建立问题
- MySQL学习之——关于or的索引问题
- Mybaties 配置文件中关于日期类型不走索引的问题
- 关于number和varchar2 走索引的问题
- 关于lucene断点续索引和增量索引的问题
- 关于索引degree设置的问题
- 关于SQL 数据库表中的聚集索引和非聚集索引等
- 关于对视图创建索引的一些问题
- 关于Lucene3.0的删除索引问题
- 关于Lucene断点续索引和增量索引的问题
- 关于SQL 数据库表中的聚集索引和非聚集索引等
- 关于多列(复合)索引使用时的一个小问题
- 遇到了一个关于for update用索引锁行的问题,悬而未解
- 使用NEWSEQUENTIALID解决GUID聚集索引问题
- 问几个问题,关于p2p搜索和分布式索引还有.net无框架打包的问题
- 关于引起更新源索引时Hash Sum mismatch问题的真正原因及解决方案