非聚集索引,聚集索引

聚集索引对范围查询比较有用,只要找到边界值所在的位置便可以确定所查询之目标范围,但是对于单个的查询是起不到多大作用的。
----应该也起作用,你可以在查询分析器查执行路径

对于每次插入前都要检查唯一性的列是不是一定要建成主键。
是不是每张表必须有个聚集索引索引,如果我不指定聚集索引,那么它以什么样的顺序进行物理排列呢?是不是先来先到的原则,早提交的在前面,后提交的在后面,每次插入只是追加,不用去挪动很多数据?
----这个问题不一定,主要看你要达到的目的,不过作开发最好是每个表都要有主键,SQL中主键本身就是聚集索引

那个填充因子从0到100,范围太大,并且我一点都不知道他的意义,不知道是做什么用的,能否给我个经验值?
----如果每个块中数据都充满了,当新的更新使比原来的数据长度大,会使索引破
碎,如果数据更新多,填充因子要大一些,反之。。。

文件组也没有理解,听您的意思,如果我存放数据的逻辑盘是由多个物理硬盘构成的,可以选择文件组来进行并行处理,可以提高性能。我的数据文件是放在多个硬盘组成的磁盘阵列中的,按理因该选文件组,但是好像只有一个primary可供选择,是否选这个就行了?
----文件组是为了更方便管理表所用的,你可以创建很多的文件组,将文件分布在
不同的组,可以控制表放在某一个文件组。
如create table a_test(id decimal(8,2)) on [second]
表示a_test创建在second文件组中,而second在另一块硬盘上。





---------------------------------------------------------------

1。聚集索引对于单个的查询比没有索引要起作用;
2。同意建立产品代号非聚集索引;
3。最好将每次插入前都要检查唯一性的列建成主键;便于查错;
4。不是每张表必须有个聚集索引,如果不指定聚集索引,是先来先到的原则;
5。60%,如果建立聚集索引,且总有中间索引插入,此值就要考虑小一些,留出空间来;但值太小,索引的层次就要增加,反过来会影响速度。
6。在磁盘阵列中的也可以建立多个文件,但意义不很大;
7。不是所有表一定得有主键,要看需要,自增列也是;

---------------------------------------------------------------

参考:
簇集索引=聚集索引:
聚集索引确定表中数据的物理顺序。聚集索引类似于电话簿,后者按姓氏排列数据。由于聚集索引规定数据在表中的物理存储顺序,因此一个表只能包含一个聚集索引。但该索引可以包含多个列(组合索引),就像电话簿按姓氏和名字进行组织一样。

聚集索引对于那些经常要搜索范围值的列特别有效。使用聚集索引找到包含第一个值的行后,便可以确保包含后续索引值的行在物理相邻。例如,如果应用程序执行的一个查询经常检索某一日期范围内的记录,则使用聚集索引可以迅速找到包含开始日期的行,然后检索表中所有相邻的行,直到到达结束日期。这样有助于提高此类查询的性能。同样,如果对从表中检索的数据进行排序时经常要用到某一列,则可以将该表在该列上聚集(物理排序),避免每次查询该列时都进行排序,从而节省成本。

非簇集索引:
非聚集索引与聚集索引一样有 B 树结构,但是有两个重大差别:

数据行不按非聚集索引键的顺序排序和存储。


非聚集索引的叶层不包含数据页。
相反,叶节点包含索引行。每个索引行包含非聚集键值以及一个或多个行定位器,这些行定位器指向有该键值的数据行(如果索引不唯一,则可能是多行)。

非聚集索引可以在有聚集索引的表、堆集或索引视图上定义。在 Microsoft® SQL Server™ 2000 中,非聚集索引中的行定位器有两种形式:

如果表是堆集(没有聚集索引),行定位器就是指向行的指针。该指针用文件标识符 (ID)、页码和页上的行数生成。整个指针称为行 ID。


如果表没有聚集索引,或者索引在索引视图上,则行定位器就是行的聚集索引键。如果聚集索引不是唯一的索引,SQL Server 2000 将添加在内部生成的值以使重复的键唯一。用户看不到这个值,它用于使非聚集索引内的键唯一。SQL Server 通过使用聚集索引键搜索聚集索引来检索数据行,而聚集索引键存储在非聚集索引的叶行内。
由于非聚集索引将聚集索引键作为其行指针存储,因此使聚集索引键尽可能小很重要。如果表还有非聚集索引,请不要选择大的列作为聚集索引的键。


唯一索引:
唯一索引可以确保索引列不包含重复的值。在多列唯一索引的情况下,该索引可以确保索引列中每个值组合都是唯一的。
唯一索引既是索引也是约束。

复合索引:
索引项是多个的就叫组合索引,也叫复合索引。
复合索引使用时需要注意索引项的次序。 

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值