MYSQL 创建索引

目录

自动索引

手动创建

主键索引

唯一索引

普通索引

创建复合索引

查看索引

删除主键


自动索引

如果我们为一张表添加主键约束、外键约束、唯一约束时,MYSQL会为对应的列自动创建一个索引。如果不指定任何约束时,MYSQL会自动为每一列生成一个索引并用ROW_ID进行标识。

手动创建

主键索引

主键索引有三种创建方式,分别是:

1.创建表时创建主键

复制代码
-- 创建表的时候指定主键
create table t_pk1(
 id bigint PRIMARY KEY auto_increment,
 name varchar(20)
);
desc t_pk1;

desc t_pk1 是查看 t_pk1表的索引信息

2.创建表时单独指定主键列

复制代码
create table t_pk(
 id bigint  auto_increment,
 name varchar(20),
 PRIMARY KEY(id)
);
desc t_pk;

3.修改表中的列为主键索引

复制代码
create table t_pk2(
 id bigint,  
 name varchar(20)
);

alter table t_pk2 add primary key (id);
alter table t_pk2 modify id bigint auto_increment;

desc t_pk2;

这是未添加之前的,每一列的信息

这是添加之后的,

唯一索引

创建唯一索引的方式有三种,和上面添加主键索引大致上是相同的,故只给出对应的代码部分。

1.创建表时创建唯一键

复制代码
create table t_uk(
 id bigint primary key auto_increment,
 name varchar(20) unique
 );
 
 desc t_uk;

2.创建表时单独指定唯一列

复制代码
create table t_uk1(
 id bigint primary key auto_increment,
 name varchar(20),
 unique (name)
 );
 
 desc t_uk1;

3.修改表中的列为唯一索引

复制代码
create table t_uk2(
 id bigint primary key auto_increment,
 name varchar(20)
 );
 
 alter table t_uk2 add unique (name);
 desc t_uk2;
普通索引

创建时机有:

  1. 创建表时,明确知道某些列频繁查询
  2. 随着业务不断发展,在版本迭代过程中添加索引

我们也可在MYSQL中查看索引信息

复制代码
show index from t_pk1;

普通索引的三种创建方式和上面两种差不多,不过还是有一些不同的。

1.创建表的时候创建普通索引

复制代码
create table t_index1(
 id bigint primary key auto_increment,
 name varchar(20) unique,
 sno varchar(20),
 index (sno)
 );

index 是创建索引的关键字,括号里是索引列

其中:主键索引用PRI表示,唯一索引用UMI表示,普通索引用MUL表示。

2.修改表中的列为普通索引

复制代码
create table t_index2(
 id bigint primary key auto_increment,
 name varchar(20) unique,
 sno varchar(20)
 );
 
 alter table t_index2 add index (sno);

3.单独创建索引并指定索引名

复制代码
create table t_index3(
 id bigint primary key auto_increment,
 name varchar(20) unique,
 sno varchar(20)
 );
 
 create index index_name on t_index3(sno);
创建复合索引

创建符合索引与创建普通索引语法相同,只不过是指定多个列,列与列之间用逗号隔开。

1.创建表时指定索引列

复制代码
create table t_index4(
 id bigint primary key auto_increment,
 name varchar(20) unique,
 sno varchar(20),
 class_id bigint,
 index(sno, class_id)
 );

2.修改表中的列为复合索引

复制代码
create table t_index5(
 id bigint primary key auto_increment,
 name varchar(20) unique,
 sno varchar(20),
 class_id bigint
 );
 
alter table t_index5 add index(sno, class_id);

3.单独创建索引并指定索引名

复制代码
create table t_index6(
 id bigint primary key auto_increment,
 name varchar(20) unique,
 sno varchar(20),
 class_id bigint
 );
 
create index t_index5_sno_class_id on t_index5 (sno, class_id);
查看索引

查看索引的三种方式,在上面都有提到,现在可以进行一下总结

  1. show keys from 表名
  2. show index from表名
  3. desc表名
删除主键

主键索引

alter table表名 drop PRIMARY KEY;

第一次使用删除语句报错的原因是:由于自增列的错误,所以下面是先删除了自增属性,然后重新删除主键。

其他索引

alter table表名 drop index 索引名

相关推荐
u868813 小时前
大模型呼叫中心助力物业报修自动化
运维·数据库·自动化
zhenxin012213 小时前
5、使用 pgAdmin4 图形化创建和管理 PostgreSQL 数据库
数据库·postgresql
keyborad pianist13 小时前
MySQl
数据库·mysql·oracle
不知名。。。。。。。。13 小时前
5、MySQL表的约束
数据库·mysql
乐之者v13 小时前
DataGrip数据导入导出
数据库
知识分享小能手13 小时前
MongoDB入门学习教程,从入门到精通,MongoDB事务知识点梳理(8)
数据库·学习·mongodb
LaughingZhu13 小时前
Product Hunt 每日热榜 | 2026-03-29
数据库·人工智能·经验分享·神经网络·chatgpt
jialan7513 小时前
不干胶管理
大数据·数据库
EasyCVR13 小时前
插件模块化集成设计:花屏蓝屏画面模糊检测...EasyCVR视频质量诊断功能的技术与落地逻辑
服务器·数据库·音视频·视频质量诊断
|华|14 小时前
mysql的备份与恢复
数据库·mysql