今天给大家带来了关于mysql的知识,在mysql中,可以利用“create unique index 索引名称 on 表名(字段名称)”语句增加唯一索引;唯一索引与普通索引类似,唯一的区别是添加唯一索引的值必须是唯一的,允许有空值,若是组合索引,则列值的组合必须唯一。
本教程适用于windows10系统、mysql8.0.22版本、Dell G3电脑。
如何在mysql中增加唯一索引
create unique index 索引名称 on 表名(字段名称)
Mysql索引大概有五种类型:
● 普通索引(INDEX):最基本的索引,没有任何限制
● 唯一索引(UNIQUE):与"普通索引"类似,不同的就是:索引列的值必须唯一,但允许有空值。
● 主键索引(PRIMARY):它 是一种特殊的唯一索引,不允许有空值。
● 全文索引(FULLTEXT ):可用于 MyISAM 表,mysql5.6之后也可用于innodb表, 用于在一篇文章中,检索文本信息的, 针对较大的数据,生成全文索引很耗时和空间。
● 联合(组合)索引:为了更多的提高mysql效率可建立组合索引,遵循”最左前缀“原则。
这里我们来看下唯一索引。
之前我们看了主键索引,他是一种特殊的唯一索引,二者的区别是,主键索引不能有空值,但是唯一索引可以有空值。
一:基本使用
1:唯一索引可以是单列,也可以是多列,下面我们来看下创建语句:
# 创建单列唯一索引 alter table sc add unique (name); # 创建多列唯一索引 alter table sc add unique key `name_score` (`name`,`score`);
2:删除唯一索引语句:
alter table sc drop index name;
在这里插入代码片
二:唯一索引作用
1:最大的所用就是确保写入数据库的数据是唯一值。
单列唯一值基本上就是主键。
常用的一般都是多列的唯一索引,比如:当前商品,一个用户只能购买一件。我们将用户id及商品id列设置成唯一索引。那么就可以避免一个用户出现重复购买的情况。
我来说两句