mysql中的key是数据库用于标识和快速定位数据的一种结构,它和索引的概念高度相关,很多时候key就是索引的另一种表述,不同的key类型对应不同的数据约束和查询优化能力。

mysql中key的核心分类
mysql里的key主要分为以下几类,每种类型都有明确的功能定位:
- PRIMARY KEY(主键):唯一标识表中每一行数据的key,一个表只能有一个主键,主键的值不能为空且不能重复。
- UNIQUE KEY(唯一键):保证对应列的值在表中唯一,允许存在空值,一个表可以有多个唯一键。
- INDEX(普通索引,也常称为KEY):仅用于提升查询速度,没有数据约束,允许重复值和空值,一个表可以有多个普通索引。
- FOREIGN KEY(外键):用于关联两张表的数据,保证参照完整性,一个表可以有多个外键。
常见key的创建方式
主键的创建
可以在建表时直接指定主键,也可以后续为表添加主键:
-- 建表时创建主键
CREATE TABLE user (
id INT NOT NULL AUTO_INCREMENT,
name VARCHAR(50) NOT NULL,
PRIMARY KEY (id)
);
-- 后续为表添加主键
ALTER TABLE user ADD PRIMARY KEY (id);
唯一键的创建
唯一键的创建方式和主键类似,只是关键字替换为UNIQUE:
-- 建表时创建唯一键
CREATE TABLE user (
id INT NOT NULL AUTO_INCREMENT,
phone VARCHAR(20) NOT NULL,
PRIMARY KEY (id),
UNIQUE KEY uk_phone (phone)
);
-- 后续添加唯一键
ALTER TABLE user ADD UNIQUE KEY uk_phone (phone);
普通索引的创建
普通索引是最常用的key类型,用于优化查询:
-- 建表时创建普通索引
CREATE TABLE user (
id INT NOT NULL AUTO_INCREMENT,
name VARCHAR(50) NOT NULL,
age INT,
PRIMARY KEY (id),
KEY idx_age (age)
);
-- 后续添加普通索引
ALTER TABLE user ADD INDEX idx_age (age);
-- 单独创建索引
CREATE INDEX idx_name ON user(name);
不同key的特性对比
我们可以通过下表清晰看到各类key的区别:
| key类型 | 唯一性 | 是否允许空值 | 一个表的数量限制 | 主要作用 |
|---|---|---|---|---|
| PRIMARY KEY | 是 | 否 | 最多1个 | 标识唯一行,提升查询速度 |
| UNIQUE KEY | 是 | 是 | 多个 | 保证数据唯一,提升查询速度 |
| 普通INDEX | 否 | 是 | 多个 | 仅提升查询速度 |
| FOREIGN KEY | 否 | 是 | 多个 | 保证表间数据参照完整性 |
key相关的注意事项
在使用mysql的key时,有几个点需要特别注意:
- 主键如果设置为自增,插入数据时可以不指定该列的值,数据库会自动生成递增的数值。
- 普通索引虽然能提升查询速度,但会增加数据插入和更新的开销,因为每次写操作都需要同步更新索引结构,不要盲目创建过多索引。
- 外键的使用会限制表的写操作性能,并且增加表结构的耦合度,现在很多业务场景中会选择在应用层实现参照完整性,而不是使用数据库外键。
- 当我们执行
SHOW CREATE TABLE 表名语句时,可以看到表中所有key的定义,其中KEY关键字后面跟着的就是普通索引的名称和对应的列。
常见问题解答
key和index是完全一样的吗
在大多数场景下,mysql里的key和index是同一个概念,比如创建普通索引时写KEY和写INDEX效果完全一致。但PRIMARY KEY和UNIQUE KEY除了是索引之外,还带有数据约束的作用,这是和普通INDEX不同的地方。
删除key的方式是什么
不同类型的key删除方式略有区别:
-- 删除主键 ALTER TABLE user DROP PRIMARY KEY; -- 删除唯一键或普通索引,需要指定索引名称 ALTER TABLE user DROP INDEX uk_phone; DROP INDEX idx_age ON user; -- 删除外键,需要指定外键名称 ALTER TABLE order_table DROP FOREIGN KEY fk_user_id;
理解mysql中key的相关概念,能帮助我们更合理地设计数据库表结构,在保障数据正确性的同时,最大化数据库的查询性能,是mysql使用过程中的基础且重要的知识点。