日期:2014-05-17  浏览次数:20541 次

数据库的索引?
mysql的聚集索引是数据库表中的主键吗?非聚集索引是只其他的列吗?刚学数据库,有点晕了,有没有学数据库的学校网站?谢谢

------解决方案--------------------
推荐 http://www.51aspx.com/
------解决方案--------------------
不管mysql 还是MSSQL(即 sql server),键/约束/索引都是不同的概念,不过有相关性:

1. 主键,外键,都会形成约束;
2. 默认值,是否为NULL,SQL Server也定义为约束;
3. 在sql server里建立主键,会默认建立聚集索引(可手动指定为非聚集索引)。
------解决方案--------------------
聚集索引:该索引中键值的逻辑顺序决定了表中相应行的物理顺序.聚集索引确定表中数据的物理顺序。聚集索引类似于电话簿,后者按姓氏排列数据。由于聚集索引规定数据在表中的物理存储顺序,因此一个表只能包含一个聚集索引。但该索引可以包含多个列(组合索引),就像电话簿按姓氏和名字进行组织一样。
聚集索引对于那些经常要搜索范围值的列特别有效。使用聚集索引找到包含第一个值的行后,便可以确保包含后续索引值的行在物理相邻。例如,如果应用程序执行 的一个查询经常检索某一日期范围内的记录,则使用聚集索引可以迅速找到包含开始日期的行,然后检索表中所有相邻的行,直到到达结束日期。这样有助于提高此 类查询的性能。同样,如果对从表中检索的数据进行排序时经常要用到某一列,则可以将该表在该列上聚集(物理排序),避免每次查询该列时都进行排序.
非聚集索引:该索引中索引的逻辑顺序与磁盘上行的物理存储顺序不同。索引是通过二叉树的数据结构来描述的,我们可以这么理解聚簇索引:索引的叶节点就是数据节点。而非聚簇索引的叶节点仍然是索引节点,只不过有一个指针指向对应的数据块。
主键就是聚集索引,这种想法是错误的,是对聚集索引的一种浪费。虽然SQL SERVER默认是在主键上建立聚集索引的。通常,我们会在每个表中都建立一个ID列,以区分每条数据,并且这个ID列是自动增大的,步长一般为1。我们的这个办公自动化的实例中的列Gid就是如此。此时,如果我们将这个列设为主键,SQL SERVER会将此列默认为聚集索引。这样做有好处,就是可以让您的数据在数据库中按照ID进行物理排序,但笔者认为这样做意义不大。显而易见,聚集索引的优势是很明显的,而每个表中只能有一个聚集索引的规则,这使得聚集索引变得更加珍贵。

------解决方案--------------------
我按SQLServer的来说说吧,毕竟你发到SQLServer专区。
1、SQLServer默认主键就有聚集索引,但是这个不是强制的,是可以根据需要改动的。主键最大的目的是为了“唯一标识一行数据”
2、聚集索引和非聚集索引完全可以有交叉。但是几乎不会有整个表上的列都有索引。
3、聚集索引特点是包含了整个表,而不仅仅是索引列。另外聚集索引是可以使得表变得有顺序,任何没有聚集索引的表都没有真正意义上的顺序。