MySQL key与index的区别
如果只是key的话,就是普通索引。
mysql的key和index多少有点令人迷惑,单独的key和其它关键词结合的key(primary key)实际表示的意义是不同,这实际上考察对数据库体系结构的了解的。
一、key
key 是数据库的物理结构,处于模型层面的,它包含两层意义和作用,一是约束(偏重于约束和规范数据库的结构完整性),二是索引(辅助查询用的)。包括primary key, unique key, foreign key 等。
primary key 有两个作用,一是约束作用(constraint),用来规范一个存储主键和唯一性,但同时也在此key上建立了一个index;
unique key 也有两个作用,一是约束作用(constraint),规范数据的唯一性,但同时也在这个key上建立了一个index;
foreign key也有两个作用,一是约束作用(constraint),规范数据的引用完整性,但同时也在这个key上建立了一个index;
可见,mysql的key是同时具有constraint和index的意义,这点和其他数据库表现的可能有区别。(至少在oracle上建立外键,不会自动建立index),因此创建key也有如下几种方式:
1.在字段级以key方式建立, 如
1
|
create
table
t
(
id
int
not
null
primary
key
)
;
|
2.在表级以constraint方式建立,如
1
|
create
table
t
(
id
int
,
CONSTRAINT
pk_t_id
PRIMARY
key
(
id
)
)
;
|
3.在表级以key方式建立,如
1
|
create
table
t
(
id
int
,
primary
key
(
id
)
)
;
|
其它key创建类似,但不管那种方式,既建立了constraint,又建立了index,只不过index使用的就是这个constraint或key。
二、 index
index是数据库的物理结构,处于实现层面的,它只是辅助查询的,它创建时会在另外的表空间(mysql中的innodb表空间)以一个类似目录的结构存储。
索引只是索引,它不会去约束索引的字段的行为(那是key要做的事情)。
Mysql常见索引有:主键索引、唯一索引、普通索引、全文索引、组合索引。
1
2
3
4
5
6
7
8
9
10
|
PRIMARY
KEY(主键索引)
ALTER
TABLE
`
table_name
`
ADD
PRIMARY
KEY
(
`
column
`
)
UNIQUE
(唯一索引
)
ALTER
TABLE
`
table_name
`
ADD
UNIQUE
(
`
column
`
)
INDEX
(普通索引
)
ALTER
TABLE
`
table_name
`
ADD
INDEX
index_name
(
`
column
`
)
FULLTEXT
(全文索引
)
ALTER
TABLE
`
table_name
`
ADD
FULLTEXT
(
`
column
`
)
组合索引
ALTER
TABLE
`
table_name
`
ADD
INDEX
index_name
(
`
column1
`
,
`
column2
`
,
`
column3
`
)
|
Mysql各种索引区别:
普通索引:最基本的索引,没有任何限制
唯一索引:与”普通索引”类似,不同的就是:索引列的值必须唯一,但允许有空值。
主键索引:它是一种特殊的唯一索引,不允许有空值。
全文索引:仅可用于 MyISAM 表,针对较大的数据,生成全文索引很耗时好空间。
组合索引:为了更多的提高mysql效率可建立组合索引,遵循”最左前缀“原则。
总结:
1.我们说索引分类,分为主键索引、唯一索引、普通索引(只有这一种才是纯粹的index)等,也是基于是不是把index看作了key。比如 create table t(id int, unique index inx_tx_id (id)); –index当作了key使用。
2.最重要的也就是,不管如何描述,理解index是纯粹的index,还是被当作key,当作key时则会有两种意义或起两种作用。
- 本文固定链接: http://www.data.5helpyou.com/article392.html
- 转载请注明: qqda熊 2016年05月25日 于 One Flower Is A World 发表