浅谈主键索引与唯一索引

来源:互联网 发布:贴吧找图软件 编辑:程序博客网 时间:2024/06/07 23:08

主键索引与唯一索引

一、主键索引定义

主键索引是唯一索引的特殊类型。
数据库表通常有一列或列组合,其值用来唯一标识表中的每一行。该列称为表的主键。
在数据库关系图中为表定义一个主键将自动创建主键索引,主键索引是唯一索引的特殊类型。主键索引要求主键中的每个值是唯一的。当在查询中使用主键索引时,它还允许快速访问数据。

它们的一些比较:
(1)对于主健/unique constraint oracle/sql server/mysql等都会自动建立唯一索引;
(2)主键不一定只包含一个字段,所以如果你在主键的其中一个字段建唯一索引还是必要的;
(3)主健可作外健,唯一索引不可;
(4)主健不可为空,唯一索引可;
(5)主健也可是多个字段的组合;
(6)主键与唯一索引不同的是:
a.有not null属性;
b.每个表只能有一个。

二、如何创建主键索引

 

ALTER TABLE `index_users`

MODIFY COLUMN `id`  int(11) NOT NULL AUTO_INCREMENT COMMENT '自增id' FIRST ,

ADD PRIMARY KEY (`id`);

 

(一)主键

主键ID,主键既是约束也是索引,同时也用于对象缓存的键值。

(二)索引

       *组合或者引用关系的子表(数据量较大的时候),需要在关联主表的列上建立非聚集索引(如订单明细表中的产品ID字段、订单明细表中关联的订单ID字段)

       *索引键的大小不能超过900个字节,当列表的大小超过900个字节或者若干列的和超过900个字节时,数据库将报错。

       *表中如果建有大量索引将会影响INSERTUPDATEDELETE语句的性能,因为在表中的数据更改时,所有的索引都将必须进行适当的调整。需要避免对经常更新的表进行过多的索引,并且索引应保持较窄,就是说:列要尽可能的少。

       *为经常用于查询的谓词创建索引,如用于下拉参照快速查找的codename等。在平台现有下拉参照的查询sql语句中的like条件语句要改成不带前置通配符。还有需要关注Order ByGroup By谓词的索引设计,Order ByGroup By的谓词是需要排序的,某些情况下为Order ByGroup By的谓词建立索引,会避免查询时的排序动作。

       *对于内容基本重复的列,比如只有10,禁止建立索引,因为该索引选择性极差,在特定的情况下会误导优化器做出错误的选择,导致查询速度极大下降。

 

      *当一个索引有多个列构成时,应注意将选择性强的列放在前面。仅仅前后次序的不同,性能上就可能出现数量级的差异。

       *对小表进行索引可能不能产生优化效果,因为查询优化器在遍历用于搜索数据的索引时,花费的时间可能比执行简单的表扫描还长,设计索引时需要考虑表的大小。记录数不大于100的表不要建立索引。频繁操作的小数量表不建议建立索引(记录数不大于5000条)

 

三、唯一索引

不允许具有索引值相同的行,从而禁止重复的索引或键值。系统在创建该索引时检查是否有重复的键值,并在每次使用 INSERT 或 UPDATE 语句添加数据时进行检查。

 

创建唯一索引的目的不是为了提高访问速度,而只是为了避免数据出现重复。唯一索引可以有多个但索引列的值必须唯一,索引列的值允许有空值。如果能确定某个数据列将只包含彼此各不相同的值,在为这个数据列创建索引的时候就应该使用关键字UNIQUE,把它定义为一个唯一索引。

 

 

创建唯一索的方法

操作表

CREATE TABLE `wb_blog` (      

`id` smallint(8) unsigned NOT NULL,      

`catid` smallint(5) unsigned NOT NULL DEFAULT '0',      

`title` varchar(80) NOT NULL DEFAULT '',

`content` text NOT NULL,

PRIMARY KEY (`id`),      

)

1、创建唯一索可以使用关键字UNIQUE随表一同创建

CREATE TABLE `wb_blog` (

`id` smallint(8) unsigned NOT NULL,

`catid` smallint(5) unsigned NOT NULL DEFAULT '0',

`title` varchar(80) NOT NULL DEFAULT '',

`content` text NOT NULL,

PRIMARY KEY (`id`),

UNIQUE KEY `catename` (`catid`)

) ;

上面代码为wb_blog表的'catid'字段创建名为catename的唯一索引

 

2、在创建表之后使用CREATE命令来创建

 CREATE UNIQUE INDEX catename ON wb_blog(catid); 如果不需要唯一索引,则可以这样删除

ALTER TABLE wb_blog DROP INDEX catename; 

原创粉丝点击