• QQ
  • nahooten@sina.com
  • 常州市九洲新世界花苑15-2

技术天地

mysql中key 、primary key 、unique key 与index区别

原创内容,转载请注明原文网址:http://homeqin.cn/a/wenzhangboke/jishutiandi/2019/0429/476.html

mysql中key 、primary key 、unique key 与index区别


索引被用来快速找出在一个列上用一特定值的行。没有索引,MySQL不得不首先以第一条记载开端并然后读完好个表直到它找出相关的行。

表越大,破费时间越多。假如表关于查询的列有一个索引,MySQL能快速抵达一个位置去搜索到数据文件的中间,没有必要思索一切数据。

假如一个表有1000行,这比次第读取至少快100倍。留意你需求存取简直一切1000行,它较快的次第读取,由于此时我们防止磁盘寻道。 

一切的MySQL索引(PRIMARY、UNIQUE和INDEX)在B树中存储。字符串是自动地紧缩前缀和结尾空间。

索援用于: 

快速找出匹配一个WHERE子句的行; 
当执行联合时,从其他表检索行; 
对特定的索引列找出MAX()或MIN()值; 
假如排序或分组在一个可用键的最左面前缀上停止(例如,ORDER BY key_part_1,key_part_2),排序或分组一个表。

假如一切键值局部跟随DESC,键以倒序被读取。 
在一些状况中,一个查询能被优化来检索值,不用咨询数据文件。

假如对某些表的一切运用的列是数字型的并且构成某些键的最左面前缀,为了更快,值能够从索引树被检索出来。 

—————————————————————————————————————————————————————————————————————————————

下面是建表的语句:

 
  1. CREATE TABLE `phpcolor_ad` (  
  2. `id` mediumint(8) NOT NULL AUTO_INCREMENT,  
  3. `namevarchar(30) NOT NULL,  
  4. `type` mediumint(1) NOT NULL,  
  5. `code` text,  
  6. PRIMARY KEY (`id`),  
  7. KEY `type` (`type`)  
  8. );  


 

最后一句的KEY `type` (`type`)是什么意义?

 

假如只是key的话,就是普通索引。

         mysql的key和index几有点令人迷惑,单独的key和其它关键词分离的key(primary key)实践表示的意义是不同,这实践上调查对数据库体系构造的理解的。
1 :

key 是数据库的物理构造,它包含两层意义和作用,

一是约束(侧重于约束和标准数据库的构造完好性),

二是索引(辅助查询用的)。

包括primary key, unique key, foreign key 等。

primary key 有两个作用,一是约束作用(constraint),用来标准一个存储主键和独一性,但同时也在此key上树立了一个主键索引;    

                          PRIMARY KEY 约束:独一标识数据库表中的每条记载;

                                                                 主键必需包含独一的值;

                                                                 主键列不能包含 NULL 值;

                                                                 每个表都应该有一个主键,并且每个表只能有一个主键。(PRIMARY KEY 具有自动定义的 UNIQUE 约束)

unique key 也有两个作用,一是约束作用(constraint),标准数据的独一性,但同时也在这个key上树立了一个独一索引;

UNIQUE 约束:独一标识数据库表中的每条记载。
                                                    UNIQUE 和 PRIMARY KEY 约束均为列或列汇合提供了独一性的保证。
                                                    (每个表能够有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束)

foreign key也有两个作用,一是约束作用(constraint),标准数据的援用完好性,但同时也在这个key上树立了一个index;

 

可见,mysql的key是同时具有constraint和index的意义,这点和其他数据库表现的可能有区别。

(至少在oracle上树立外键,不会自动树立index),因而创立key也有如下几种方式:
(1)在字段级以key方式树立, 如 create table t (id int not null primary key);
(2)在表级以constraint方式树立,如create table t(id int, CONSTRAINT pk_t_id PRIMARY key (id));
(3)在表级以key方式树立,如create table t(id int, primary key (id));

其它key创立相似,但不论那种方式,既树立了constraint,又树立了index,只不过index运用的就是这个constraint或key。

 


2: index是数据库的物理构造,它只是辅助查询的,它创立时会在另外的表空间(mysql中的innodb表空间)以一个相似目录的构造存储。索引要分类的话,分为前缀索引、全文本索引等;
        因而,索引只是索引,它不会去约束索引的字段的行为(那是key要做的事情)。如,create table t(id int,index inx_tx_id (id));


3 总结,最后的释疑:
(1)我们说索引分类,分为

主键索引(必需指定为“PRIMARY KEY”,没有PRIMARY Index)、

独一索引(unique index,普通写成unique key)、

普通索引(index,只要这一种才是地道的index)等,也是基于是不是把index看作了key。
           比方 create table t(id int, unique indexinx_tx_id (id));--index当作了key运用

(2)最重要的也就是,不论如何描绘,需求了解index是地道的index(普通的key,或者普通索引index),还是被当作key(如:unique index、unique key和primary key),若当作key时则会有两种意义或起两种作用。

—————————————————————————————————————————————————————————————————————————————

MySQL Key值(PRI, UNI, MUL)的含义:

PRI主键约束;

UNI独一约束;

MUL能够反复。

注:若是普通的key或者普通的index(实践上,普通的key与普通的index同义)。

 

当我们在desc 表名; 的时分,有一个Key值,表示该列能否含有索引
假定表构造如下所示
mysql> desc aa;
+-------+---------+------+-----+---------+-------+
| Field | Type    | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| id    | int(11) | YES  |     | NULL    |       |
+-------+---------+------+-----+---------+-------+
| xx    | int(11) | YES  | PRI | NULL    |       |
+-------+---------+------+-----+---------+-------+
| yy    | int(11) | YES  | UNI | NULL    |       |
+-------+---------+------+-----+---------+-------+
| zz    | int(11) | YES  | MUL | NULL    |       |
+-------+---------+------+-----+---------+-------+
1 row in set (0.00 sec)

我们看到Key那一栏,可能会有4种值,即'啥也没有','PRI','UNI','MUL'
1. 假如Key是空的, 那么该列值的能够反复,表示该列没有索引, 或者是一个非独一的复合索引的非前导列
2. 假如Key是PRI,  那么该列是主键的组成局部
3. 假如Key是UNI,  那么该列是一个独一值索引的第一列(前导列),且不能含有空值(NULL)
4. 假如Key是MUL,  那么该列的值能够反复, 该列是一个非独一索引的前导列(第一列)或者是一个独一性索引的组成局部但是能够含有空值NULL

注:
1、假如关于一个列的定义,同时满足上述4种状况的多种,比方一个列既是PRI,又是UNI(假如是PRI,则一定是UNI)
那么"desc 表名"; 的时分,显现的Key值依照优先级来显现 PRI->UNI->MUL
那么此时,显现PRI。

2、假如某列不能含有空值,同时该表没有主键,则一个独一性索引列能够显现为PRI,

3、假如多列构成了一个独一性复合索引,那么一个独一性索引列能够显现为MUL。(由于固然索引的多列组合是独一的,比方ID+NAME是独一的,但是每一个单独的列仍然能够有反复的值,由于只需ID+NAME是独一的即可)

 

 

一、key与primary key区别 

 

[sql] view plain copy
 
 print?
  1. CREATE TABLE wh_logrecord (   
  2. logrecord_id int(11) NOT NULL auto_increment,   
  3. user_name varchar(100) default NULL,   
  4. operation_time datetime default NULL,   
  5. logrecord_operation varchar(100) default NULL,   
  6. PRIMARY KEY (logrecord_id),   
  7. KEY wh_logrecord_user_name (user_name)   
  8. )   


解析: 
KEY wh_logrecord_user_name (user_name) 
本表的user_name字段与wh_logrecord_user_name表user_name字段树立外键 
括号外是树立外键的对应表,括号内是对应字段 
相似还有 KEY user(userid) 
当然,key一定都是外键 

总结: 
Key是索引约束,对表中字段停止约束索引的,都是经过primary foreign unique等创立的。常见有foreign key,外键关联用的。 

KEY forum (status,type,displayorder)  # 是多列索引(键) 
KEY tid (tid)                         # 是单列索引(键)。 

如建表时: KEY forum (status,type,displayorder) 
select * from table group by status,type,displayorder 能否就自动用上了此索引, 
而当 select * from table group by status 此索引有用吗? 

key的用处:主要是用来加快查询速度的。 

 

[sql] view plain copy
 
 print?
  1. CREATE TABLE `admin_role` (  
  2.   `adminSet_id` varchar(32) NOT NULL,  
  3.   `roleSet_id` varchar(32) NOT NULL,  
  4.   PRIMARY KEY (`adminSet_id`,`roleSet_id`),  
  5.   KEY `FK9FC63FA6DAED032` (`adminSet_id`),  
  6.   KEY `FK9FC63FA6C7B24C48` (`roleSet_id`)  
  7. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;  

主键,两个列组合在一同,是独一的,内建独一性索引,并且不能为NULL
另外,两个Key定义,相当于分别对这两列树立索引。

 

 

innodb
primary key   主键汇集索引
key 普通索引

 

二、KEY与INDEX区别 

KEY通常是INDEX同义词。假如关键字属性PRIMARY KEY在列定义中已给定,则PRIMARY KEY也能够只指定为KEY。

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

PRIMARY KEY是一个独一KEY,此时,一切的关键字列必需定义为NOT NULL。

假如这些列没有被明白地定义为NOT NULL,MySQL应隐含地定义这些列。一个表只要一个PRIMARY KEY。 



MySQL 中Index 与Key 的区别 

Key即键值,是关系模型理论中的一部份,比方有主键(Primary Key),外键(Foreign Key)等,用于数据完好性检否与独一性约束等。

而Index则处于完成层面,比方能够对表的恣意列树立索引,那么当树立索引的列处于SQL语句中的Where条件中时,就能够得到快速的数据定位,从而快速检索。

至于Unique Index,则只是属于Index中的一种而已,树立了Unique Index表示此列数据不可反复,猜测MySQL对Unique Index类型的索引能够做进一步特殊优化吧。 


于是乎,在设计表的时分,Key只是要处于模型层面的,而当需求停止查询优化,则对相关列树立索引即可。 

另外,在MySQL中,关于一个Primary Key的列,MySQL曾经自动对其树立了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). 

三、mysql中UNIQUE KEY和PRIMARY KEY有什么区别 

1,Primary key的1个或多个列必需为NOT NULL,假如列为NULL,在增加PRIMARY KEY时,列自动更改为NOT NULL。

而UNIQUE KEY 对列没有此请求 

2,一个表只能有一个PRIMARY KEY,但能够有多个UNIQUE KEY 

3,主键和独一键约束是经过参考索引施行的,假如插入的值均为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);#能够反复 

四、运用UNIQUE KEY 

[sql] view plain copy
 
 print?
  1. CREATE TABLE `secure_vulnerability_warning` (   
  2.   `id` int(10) NOT NULL auto_increment,   
  3.   `datedate NOT NULL,   
  4.   `type` varchar(100) NOT NULL,   
  5.   `sub_type` varchar(100) NOT NULL,   
  6.   `domain_name` varchar(128) NOT NULL,   
  7.   `url` text NOT NULL,   
  8.   `parameters` text NOT NULL,   
  9.   `hash` varchar(100) NOT NULL,   
  10.   `deal` int(1) NOT NULL,   
  11.   `deal_date` date default NULL,   
  12.   `remark` text,   
  13.   `last_push_time` datetime default NULL,   
  14.   `push_times` int(11) default '1',   
  15.   `first_set_ok_time` datetime default NULL,   
  16.   `last_set_ok_time` datetime default NULL,   
  17.   PRIMARY KEY  (`id`),   
  18.   UNIQUE KEY `date` (`date`,`hash`)   
  19. ) ENGINE=InnoDB  DEFAULT CHARSET=utf8   

UNIQUE KEY的用处:主要是用来避免数据插入的时分反复的。 

1,创立表时 

[sql] view plain copy
 
 print?
  1. CREATE TABLE Persons   
  2. (   
  3. Id_P int NOT NULL,   
  4. LastName varchar(255) NOT NULL,   
  5. FirstName varchar(255),   
  6. Address varchar(255),   
  7. City varchar(255),   
  8. UNIQUE (Id_P)   
  9. )   

假如需求命名 UNIQUE 约束,以及为多个列定义 UNIQUE 约束,请运用下面的 SQL 语法: 
[sql] view plain copy
 
 print?
  1. CREATE TABLE Persons   
  2. (   
  3. Id_P int NOT NULL,   
  4. LastName varchar(255) NOT NULL,   
  5. FirstName varchar(255),   
  6. Address varchar(255),   
  7. City varchar(255),   
  8. CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName)   
  9. )   

2,当表已被创立时,如需在 "Id_P" 列创立 UNIQUE 约束,请运用下列 SQL: 

[sql] view plain copy
 
 print?
  1. ALTER TABLE Persons   
  2. ADD UNIQUE (Id_P)   

如需命名 UNIQUE 约束,并定义多个列的 UNIQUE 约束,请运用下面的 SQL 语法: 

[sql] view plain copy
 
 print?
  1. ALTER TABLE Persons   
  2. ADD CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName)   

3,撤销 UNIQUE 约束 

如需撤销 UNIQUE 约束,请运用下面的 SQL: 


[sql] view plain copy
 
 print?
  1. ALTER TABLE Persons   
  2. DROP INDEX uc_PersonID   


上篇:上一篇:织梦挪用上一篇下一篇以及样式点窜
下篇:下一篇:常用的织梦calling标签