Mysql中普通索引key、主键索引(primarykey)、唯⼀索引(uniquekey。。。⼀、索引的定义和由来:
索引被⽤来快速找出在⼀个列上⽤⼀特定值的⾏。没有索引,MySQL不得不⾸先以第⼀条记录开始并然后读完整个表直到它找出相关的⾏。
表越⼤,花费时间越多。如果表对于查询的列有⼀个索引,MySQL能快速到达⼀个位置去搜寻到数据⽂件的中间,没有必要考虑所有数据。
所有的MySQL索引(PRIMARY、UNIQUE和INDEX)在B-tree树中存储。字符串是⾃动地压缩前缀和结尾空间
⼆、索引的分类
1、普通索引key
如下建表语句:
CREATE TABLE `phpcolor_ad` (
`id` mediumint(8) NOT NULL AUTO_INCREMENT,
`name` varchar(30) NOT NULL,
`type` mediumint(1) NOT NULL,
`code` text,
PRIMARY KEY (`id`),
KEY `type` (`type`)
);
最后⼀句的KEY `type` (`type`)是什么意思?
如果只是key的话,就是普通索引。
mysql的key和index多少有点令⼈迷惑,单独的key和其它关键词结合的key(primary key)实际表⽰的意义是不同,这实际上考察对数据库体系结构的了解的。
key 是数据库的物理结构,它包含两层意义和作⽤,
⼀是约束(偏重于约束和规范数据库的结构完整性),
托福考试
⼆是索引(辅助查询⽤的)。
包括primary key, unique key, foreign key 等。
2、主键索引primary key
primary key 有两个作⽤,⼀是约束作⽤(constraint),⽤来规范⼀个存储主键和唯⼀性,但同时也在此key上建⽴了⼀个主键索引;
PRIMARY KEY 约束:唯⼀标识数据库表中的每条记录;
主键必须包含唯⼀的值;
主键列不能包含 NULL 值;
每个表都应该有⼀个主键,并且每个表只能有⼀个主键。(PRIMARY KEY 拥有⾃动定义的 UNIQUE 约束)
3、唯⼀索引unique key
unique key 也有两个作⽤,⼀是约束作⽤(constraint),规范数据的唯⼀性,但同时也在这个key上
建⽴了⼀个唯⼀索引;
UNIQUE 约束:唯⼀标识数据库表中的每条记录。
UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯⼀性的保证。
(每个表可以有多个 UNIQUE 约束,但是每个表只能有⼀个 PRIMARY KEY 约束)
foreign key 也有两个作⽤,⼀是约束作⽤(constraint),规范数据的引⽤完整性,但同时也在这个key上建⽴了⼀个index;
可见,mysql的key是同时具有constraint和index的意义,这点和其他数据库表现的可能有区别。
(⾄少在Oracle上建⽴外键,不会⾃动建⽴index),因此创建key也有如下⼏种⽅式:
mpkg(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。
4、普通索引index
index是数据库的物理结构,它只是辅助查询的,它创建时会在另外的表空间(mysql中的innodb表空间)以⼀个类似⽬录的结构存储。索引要分类的话,分为前缀索引、全⽂本索引等;
因此,索引只是索引,它不会去约束索引的字段的⾏为(那是key要做的事情)。如,create table t(id int,index inx_tx_id (id));
5、总结,最后的释疑:
(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 t (0.00 c)
我们看到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区别
CREATE TABLE wh_logrecord (
2013年12月英语四级真题及答案logrecord_id int(11) NOT NULL auto_increment,
ur_name varchar(100) default NULL,
operation_time datetime default NULL,
logrecord_operation varchar(100) default NULL,
PRIMARY KEY (logrecord_id),
KEY wh_logrecord_ur_name (ur_name)
);
解析:
国务委员是什么意思
KEY wh_logrecord_ur_name (ur_name)
本表的ur_name字段与wh_logrecord_ur_name表ur_name字段建⽴外键
免费词典括号外是建⽴外键的对应表,括号内是对应字段
类似还有 KEY ur(urid)
当然,key未必都是外键
总结:
Key是索引约束,对表中字段进⾏约束索引的,都是通过primary foreign unique等创建的。常见有foreign key,外键关联⽤的。
6 5
KEY forum (status,type,displayorder) # 是多列索引(键)
KEY tid (tid) # 是单列索引(键)。
如建表时: KEY forum (status,type,displayorder)
lect * from table group by status,type,displayorder 是否就⾃动⽤上了此索引,
⽽当 lect * from table group by status 此索引有⽤吗?
key的⽤途:主要是⽤来加快查询速度的。
CREATE TABLE `admin_role` (
`adminSet_id` varchar(32) NOT NULL,
`roleSet_id` varchar(32) NOT NULL,
PRIMARY KEY (`adminSet_id`,`roleSet_id`),
KEY `FK9FC63FA6DAED032` (`adminSet_id`),
KEY `FK9FC63FA6C7B24C48` (`roleSet_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
主键,两个列组合在⼀起,是唯⼀的,内建唯⼀性索引,并且不能为NULL
另外,两个Key定义,相当于分别对这两列建⽴索引。
innodb
primary key 主键聚集索引
key 普通索引
四、KEY与INDEX区别
KEY通常是INDEX同义词。如果关键字属性PRIMARY KEY在列定义中已给定,则PRIMARY KEY也可以只指定为KEY。
这么做的⽬的是与其它数据库系统兼容。
出埃及记马克西姆钢琴曲mp3下载
pickoutPRIMARY 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 databa 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);
inrt into t (a ,b ) values (null,1); # 不能重复
inrt into t (a ,b ) values (null,null);#可以重复
六、使⽤UNIQUE KEY
零基础学习英语CREATE TABLE `cure_vulnerability_warning` (
`id` int(10) NOT NULL auto_increment,
`date` date NOT NULL,
`type` varchar(100) NOT NULL,
`hash` varchar(100) NOT NULL,
`deal` int(1) NOT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `date` (`date`,`hash`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
cryptUNIQUE KEY的⽤途:主要是⽤来防⽌数据插⼊的时候重复的。
1,创建表时
CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
UNIQUE (Id_P)
);
如果需要命名 UNIQUE 约束,以及为多个列定义 UNIQUE 约束,请使⽤下⾯的 SQL 语法:
CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName)
)
;
2,当表已被创建时,如需在 "Id_P" 列创建 UNIQUE 约束,请使⽤下列 SQL:
ALTER TABLE Persons
ADD UNIQUE (Id_P);
如需命名 UNIQUE 约束,并定义多个列的 UNIQUE 约束,请使⽤下⾯的 SQL 语法:
ALTER TABLE Persons
ADD CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName); 3,撤销 UNIQUE 约束
如需撤销 UNIQUE 约束,请使⽤下⾯的 SQL:ALTER TABLE Persons
DROP INDEX uc_PersonID;