msql唯一索引

Mysql唯一索引 唯一约束

唯一索引作为mysql众多索引常用的一种,在一次业务代码编写中详细了解了下此索引在此记载,如果错误地方还望同学们斧正

唯一索引的的作用

顾名思义,唯一索引,即是唯一的意思,在数据库表结构中对字段添加唯一索引后进行数据库进行存储操作时数据库会判断库中是否已经存在此数据,不存在此数据时才能进行插入操作。

这虽然是个小技能,但实际上在业务开发中是个很实用的技能, 比如在高并发业务中,数据库单实例的话如何杜绝数据并发插入两条相同的订单号呢? 添加一个唯一索引当然是最快捷的方法之一,当然是添加索引还是通过业务代码去解决因公司业务而定

唯一索引与唯一约束的区别

对于这两个不同的名词百度了很久,在mysql中貌似唯一约束就是唯一索引,并没有什么不同,可能叫法不同,在sqlserver中区分还是挺明确的。 sqlserver唯一索引和约束的区别

博客中的一句话说的很在理,你为了做到数据不能有重复值,但是数据库怎么保证没有重复值呢?当然是在存储数据的时候查一遍,那么怎样查找快呢? 当然是创建索引,所以,在创建唯一约束的时候就创建了唯一索引。这可能也是mysql的一个优化机制

添加/删除唯一索引的sql语句

添加索引

alter table table_name add unique(column)

删除索引

alter table table_name drop index colum_name

需要注意的坑

再添加唯一索引后还有一种特殊情况,那就是如果该字段没有限制非空的话,存在插入NULL值的情况,此时,唯一索引并不起作用,也就是你可以插入n条该字段为null的数据。

除此之外,如果插入空字符串的话, 
例如 
‘’ 
‘ ’ 
不管中间是多少个空字符串在插入的时候都算作‘’ ,即,空串不论多长,只能插入一条。具体代码大家可以自己实现一下

猜你喜欢

转载自blog.csdn.net/qq_37391017/article/details/81866221