日期:2014-05-18  浏览次数:20449 次

qq面试题 关于数据库索引
问建立索引的那一列,值要求唯一吗?

哪位给我讲讲?

------解决方案--------------------
唯一索引的话,要求值唯一.
主键要求值唯一.
复合索引不用.
------解决方案--------------------
索引类型
根据数据库的功能,可在数据库设计器中创建三种类型的索引 — 唯一索引、主键索引和聚集索引。

提示 尽管唯一索引有助于找到信息,但为了获得最佳性能,建议使用主键约束或唯一约束。有关这些约束的更多信息,请参见主键约束和唯一约束。

唯一索引
唯一索引不允许两行具有相同的索引值。

如果现有数据中存在重复的键值,则大多数数据库都不允许将新创建的唯一索引与表一起保存。当新数据将使表中的键值重复时,数据库也拒绝接受此数据。例如,如果在 employee 表中的职员姓氏 (lname) 列上创建了唯一索引,则所有职员不能同姓。

有关唯一索引的更多信息,请参见创建唯一索引。

主键索引
数据库表通常有一列或列组合,其值用来唯一标识表中的每一行。该列称为表的主键。

在数据库关系图中为表定义一个主键将自动创建主键索引,主键索引是唯一索引的特殊类型。主键索引要求主键中的每个值是唯一的。当在查询中使用主键索引时,它还允许快速访问数据。有关主键的更多信息,请参见定义主键。

聚集索引
在聚集索引中,表中各行的物理顺序与键值的逻辑(索引)顺序相同。表只能包含一个聚集索引。

如果不是聚集索引,表中各行的物理顺序与键值的逻辑顺序不匹配。聚集索引比非聚集索引有更快的数据访问速度。

有关使用聚集索引的更多信息,请参见创建聚集索引。


如果是复合索引一列内允许有重复的数据
------解决方案--------------------
不对,只有unique索引要求唯一,其它的没有要求,你没有把索引和主键分开
------解决方案--------------------
不对,聚集索引和非聚集索引都可以有唯一也都可以没有
------解决方案--------------------
聚集索引和非聚集索引 是按索引的物理存储方式来分的,(所以聚集索引只能有一个)
唯一性是按索引值能否重复来分的,
复合索引是按索引列是否是一列还多列分的,
他们是不同的分法,可以相互交错
主键是特殊的聚集索引(要唯一由主键定义决定),unique是特殊的非聚集索引(要唯一)
------解决方案--------------------
只有主键 与 唯一索引(unique) 要求唯一 其他的聚集与非聚集索引列的数据都可以重复