如下图所示,在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或者native的,但是如果是drds的话他的expalin的展现形式会变成这样
对于一般正常的数据库会是这样
所以,这个可能需要其他的途径解决