美洲杯波胆_美洲杯波胆赔率
做最好的网站
来自 计算机教程 2019-12-14 06:54 的文章
当前位置: 美洲杯波胆 > 计算机教程 > 正文

MySQL中KEY、PRIMARY KEY、UNIQUE KEY、INDEX 的区别_Mysq

本文章来给大家介绍在mysql中unique与primary约束的区别分析,unique与primary是我们在创建mysql时常用的类型了,下面我来给大家介绍介绍。

对于题目中提出的问题,可以拆分来一步步解决。在 MySQL 中 KEY 和 INDEX 是同义。那这个问题就可以简化为 PRIMARY KEY,UNIQUE KEY 和 INDEX 的区别。而这三者也正好是索引的划分,主键索引,唯一索引和普通索引。

定义了UNIQUE约束的字段中不能包含重复值,可以为一个或多个字段定义UNIQUE约束,因此,UNIQUE即可以在字段级也可以在表级定义,在UNIQUE约束的字段上可以包含空值. ORACLE自动会为具有PRIMARY KEY约束的字段(主码字段)建立一个唯一索引和一个NOT NULL约束,定义PRIMARY KEY约束时可以为它的索引; UNIQUED 可空,可以在一个表里的一个或多个字段定义;  

使用 INDEX 来加速从数据库中读取数据。INDEX 通常加在那些 JOIN, WHERE,和 ORDER BY 子句的列上。

PRIMARY KEY不可空不可重复,在一个表里可以定义联合主键;简单的说, primary key = unique not null

创建索引时,需要确保该索引是应用在 SQL 查询语句的条件。 实际上,索引也是一张表,该表保存了主键与索引字段,并指向实体表的记录。

 
unique就是唯一,当你需要限定你的某个表字段每个值都唯一,没有重复值时使用. 比如说,如果你有一个person_Info表,并且表中有个身份证的column,那么你就可以指定该字段unique.

索引也有它的缺点:虽然索引提高了查询速度,却会降低更新表的速度,如对表进行INSERT、UPDATE和DELETE。因为更新表时,MySQL不仅要保存数据,还要保存一下索引文件。

 
从技术的角度来看,Primary Key和Unique Key有很多相似之处。但还是有以下异同:  

MySQL 中 KEY 与 INDEX 区别

相同:它们都属于实体完整性约束.

KEY 通常是 INDEX 同义词。如果关键字属性 PRIMARY KEY 在列定义中已给定,则 PRIMARY KEY 也可以只指定为KEY。这么做的目的是与其它数据库系统兼容。 PRIMARY KEY 是一个唯一 KEY,此时,所有的关键字列必须定义为NOT NULL。如果这些列没有被明确地定义为NOT NULL,MySQL应隐含地定义这些列。

 

KEY 即键值,是关系模型理论中的一部份,比如有主键,外键等,用于数据完整性检否与唯一性约束等。而 INDEX 则处于实现层面,比如可以对表个的任意列建立索引,那么当建立索引的列处于SQL语句中的Where条件中时,就可以得到快速的数据定位,从而快速检索。至于UNIQUE INDEX,则只是属于INDEX中的一种而已,建立了UNIQUE INDEX表示此列数据不可重复,猜想MySQL对UNIQUE INDEX类型的索引可以做进一步特殊优化吧。

表结构:

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

 代码如下

KEY

复制代码

KEY 是数据库的物理结构,包含两层含义,一是约束,偏重于约束和规范数据库的结构完整性,二是索引,辅助查询。•primary key 有两个作用,一是约束作用,用来规范一个存储主键和唯一性,但同时也在此key上建立了一个index;•unique key 也有两个作用,一是约束作用,规范数据的唯一性,但同时也在这个key上建立了一个index;•foreign key也有两个作用,一是约束作用,规范数据的引用完整性,但同时也在这个key上建立了一个index;

CREATE TABLE `good_booked` (
  `auto_id` int(10) NOT NULL auto_increment,
  `good_id` int(11) default NULL,
  `chemist_id` int(11) default NULL,
  PRIMARY KEY  (`auto_id`),
  UNIQUE KEY `good_id` (`good_id`,`chemist_id`),
  KEY `current_state` (`current_state`),
  KEY `send_time` (`send_time`)
)

可见,key是同时具有constraint和index的意义.

想删除某个表中某个字段的unique key:   

INDEX

 代码如下

INDEX 也是数据库的物理结构,但他只有辅助查询作用,它会在创建时占用另外的空间。索引分为前缀索引、全文索引等。索引只是索引,不会去约束索引字段的行为。

复制代码

PRIMARY KEY 和 UNIQUE KEY 的区别

ALTER TABLE good_booked DROP INDEX good_id;

PRIMARY KEYs 和 UNIQUE KEYs 是类似的, PRIMARY KEY通常是一列,也有可能多列,通常由他来决定一行数据。 一张表只能有一个 PRIMARY KEY,但可以有很多 UNIQUE KEY。 当给一列设置为 UNIQUE KEY 之后,不能有两行在该列上有相同的数据。 PRIMARY KEY 不允许有 NULL值,但是 UNIQUE KEY 可以。

UNIQUE防止重复插入数据示例

修改表 `ALTER TABLE table_name ADD PRIMARY KEY

当unique列在一个UNIQUE键上插入包含重复值的记录时,我们可以控制MySQL如何处理这种情况:使用IGNORE关键字或者ONDUPLICATEKEYUPDATE子句跳过INSERT、中断操作或者更新旧记录为新值。这样就可以防止数据库中存在重复的数据项

总结,相同点:•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 ; insert into t values ; # 不能重复 insert into t values ;#可以重复

mysql>createtablemenus(idtinyint(4)notnullauto_increment,
->labelvarchar(10)null,urlvarchar(20)null,uniquekey(id));
QueryOK,0rowsaffected(0.13sec)
mysql>insertintomenus(label,url)values(“Home”,”home.html”);
QueryOK,1rowaffected(0.06sec)
mysql>insertintomenus(label,url)values(“Aboutus”,”aboutus.html”);
QueryOK,1rowaffected(0.05sec)
mysql>insertintomenus(label,url)values(“Services”,”services.html”);
QueryOK,1rowaffected(0.05sec)
mysql>insertintomenus(label,url)values(“Feedback”,”feedback.html”);
QueryOK,1rowaffected(0.05sec)

在MySQL中,对于一个PRIMARY KEY的列,MySQL已经自动对其建立了UNIQUE INDEX,无需重复再在上面建立索引了。

mysql>select*frommenus;
—- ———- —————
|id|label|url|
—- ———- —————
|1|Home|home.html|
|2|Aboutus|aboutus.html|
|3|Services|services.html|
|4|Feedback|feedback.html|
—- ———- —————
4rowsinset(0.00sec)

网上关于 PRIMARY KEY 和 UNIQUE INDEX 的一段解释:

如果现在在unique列插入一条违背唯一约束的记录,MySQL会中断操作,提示出错:

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 UNIQUE INDEX created .

 代码如下

操作索引

本文由美洲杯波胆发布于计算机教程,转载请注明出处:MySQL中KEY、PRIMARY KEY、UNIQUE KEY、INDEX 的区别_Mysq

关键词: