mysql 联合唯一索引失效

如下图所示,在mysql 一张表中 联合唯一索引按照业务要求由三个字段构成 , 其中name和isbn是varhar,type是tinyint

然后又一次查询接口返回报错,提示返回了多个结果,然后我一看表里面,有同样的两条数据,其中name和type有值,但是isbn是NULL。这个时候我去查询资料发现联合唯一索引中,要是有一个存在null那么整个都会失效。可是,为什么会这样呢?要是是联合索引的话会不会也失效呢?这就需要我们来探索下索引这个东西了。

参考一篇写的很好的文章关于索引的基本都讲到了,

http://blog.codinglabs.org/articles/theory-of-mysql-index.html

但是对于b_tree和b+tree实际上讲的不是很详细,可以看这篇文章

https://www.cnblogs.com/gym333/p/6877023.html

这个图就一目了然了

mysql 联合唯一索引失效_第1张图片

另外看的途中我们自己要在本机做测试的话需要安装mysql或者native的,但是如果是drds的话他的expalin的展现形式会变成这样

mysql 联合唯一索引失效_第2张图片

对于一般正常的数据库会是这样

mysql 联合唯一索引失效_第3张图片

所以,这个可能需要其他的途径解决

你可能感兴趣的:(mysql索引)