MySQL中KEY、PRIMARYKEY、UNIQUEKEY、INDEX的区别

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

MySQL中KEY、PRIMARYKEY、UNIQUEKEY、INDEX的
区别
对于题⽬中提出的问题,可以拆分来⼀步步解决。

在 MySQL 中 KEY 和 INDEX 是同义。

那这个问题就可以简化为 PRIMARY KEY,UNIQUE KEY 和 INDEX 的区别。

⽽这三者也正好是索引的划分,主键索引,唯⼀索引和普通索引(INDEX)。

使⽤ INDEX 来加速从数据库中读取数据。

INDEX 通常加在那些 JOIN, WHERE,和 ORDER BY ⼦句的列上。

创建索引时,需要确保该索引是应⽤在 SQL 查询语句的条件(⼀般作为 WHERE ⼦句的条件)。

实际上,索引也是⼀张表,该表保存了主键与索引字段,并指向实体表的记录。

索引也有它的缺点:虽然索引提⾼了查询速度,却会降低更新表的速度,如对表进⾏INSERT、UPDATE和DELETE。

因为更新表时,MySQL不仅要保存数据,还要保存⼀下索引⽂件。

MySQL 中 KEY 与 INDEX 区别
KEY 通常是 INDEX 同义词。

如果关键字属性 PRIMARY KEY 在列定义中已给定,则 PRIMARY KEY 也可以只指定为KEY。

这么做的⽬的是与其它数据库系统兼容。

PRIMARY KEY 是⼀个唯⼀ KEY,此时,所有的关键字列必须定义为NOT NULL。

如果这些列没有被明确地定义为NOT NULL,MySQL应隐含地定义这些列。

KEY 即键值,是关系模型理论中的⼀部份,⽐如有主键(PRIMARY KEY),外键(Foreign KEY)等,⽤于数据完整性检否与唯⼀性约束等。

⽽ INDEX 则处于实现层⾯,⽐如可以对表个的任意列建⽴索引,那么当建⽴索引的列处于SQL语句中的Where条件中时,就可以得到快速的数据定位,从⽽快速检索。

⾄于UNIQUE INDEX,则只是属于INDEX中的⼀种⽽已,建⽴了UNIQUE INDEX表⽰此列数据不可重复,猜想MySQL对UNIQUE INDEX类型的索引可以做进⼀步特殊优化吧。

于是,在设计表的时候,KEY只是要处于模型层⾯的,⽽当需要进⾏查询优化,则对相关列建⽴索引即可。

KEY
KEY 是数据库的物理结构,包含两层含义,⼀是约束,偏重于约束和规范数据库的结构完整性,⼆是索引,辅助查询。

•primary key 有两个作⽤,⼀是约束作⽤(constraint),⽤来规范⼀个存储主键和唯⼀性,但同时也在此key上建⽴了⼀个index;
•unique key 也有两个作⽤,⼀是约束作⽤(constraint),规范数据的唯⼀性,但同时也在这个key上建⽴了⼀个index;•foreign key也有两个作⽤,⼀是约束作⽤(constraint),规范数据的引⽤完整性,但同时也在这个key上建⽴了⼀个index;可见,key是同时具有constraint和index的意义.
INDEX
INDEX 也是数据库的物理结构,但他只有辅助查询作⽤,它会在创建时占⽤另外的空间。

索引分为前缀索引、全⽂索引等。

索引只是索引,不会去约束索引字段的⾏为。

PRIMARY KEY 和 UNIQUE KEY 的区别
PRIMARY KEYs(主键)和 UNIQUE KEYs(唯⼀键约束)是类似的, PRIMARY KEY通常是⼀列,也有可能多列,通常由他来决定⼀⾏数据(row)。

⼀张表只能有⼀个 PRIMARY KEY,但可以有很多 UNIQUE KEY。

当给⼀列设置为 UNIQUE KEY 之后,不能有两⾏在该列上有相同的数据。

PRIMARY KEY 不允许有 NULL值,但是 UNIQUE KEY 可以。

修改表`ALTER TABLE table_name ADD PRIMARY KEY(column_name, …)
总结,相同点:
•PRIMARY KEY 和 UNIQUE KEY 都是⽤来保证列上数据的为原型
•都可以在⼀列或者多列上加
差异点:
•同⼀张表 PRIMARY KEY 只能有⼀个, UNIQUE KEY可以有多个

PRIMARY KEY 不能有空值, UNIQUE KEY 可以有。

如果 PRIMARY KEY 的1个或多个列为NULL,在增加PRIMARY KEY 时,列⾃动更改为 NOT NULL 。

⽽UNIQUE KEY 对列没有要求是通过参考索引实施的,如果插⼊的值均为NULL,则根据索引的原理,全NULL值不被记录在索引上,所以插⼊全NULL值时,可以有重复的,⽽其他的则不能插⼊重复值。

alter table t add constraint uk_t_1 UNIQUE (a,b); insert into t (a ,b ) values (null,1); # 不能重复 insert into t (a ,b ) values (null,null);#可以重复
在MySQL中,对于⼀个PRIMARY KEY的列,MySQL已经⾃动对其建⽴了UNIQUE INDEX,⽆需重复再在上⾯建⽴索引了。

⽹上关于 PRIMARY KEY 和 UNIQUE INDEX 的⼀段解释:
Note that “PRIMARY” is called PRIMARY KEY not INDEX. KEY is something on the logical level, describes your table and database design (i.e. enforces referential integrity …) INDEX is something on the physical level, helps improve access time for table operations. Behind every PK there is (usually) UNIQUE INDEX created (automatically).
操作索引
建⽴索引会占⽤磁盘空间的索引⽂件。

CREATE INDEX IndexName ON mytable(username(length));
如果是 CHAR,VARCHAR 类型,length 可以⼩于字段实际长度;如果是 BLOB 和 TEXT类型,必须指定 length。

在创建表时创建索引:
CREATE TABLE mytable(
ID INT NOT NULL,
username VARCHAR(15) NOT NULL,
INDEX [INDEXName] (username(length))
);
删除索引
DROP INDEX [INDEXName] ON mytable;。

相关文档
最新文档