主页 > 知识库 > MySQL中NULL对索引的影响深入讲解

MySQL中NULL对索引的影响深入讲解

热门标签:昌德讯外呼系统 徐泾镇腾讯地图标注 天津公司外呼系统软件 中国地图标注公司 福建外呼电销机器人加盟 400电话申请厂家现货 百度地图标注要什么软件 电话机器人的价格多少钱一个月 自己做地图标注需要些什么

前言

看了很多博客,也听过很多人说,包括我们公司的DBA,说MySql中如果某一列中含有null,那么包含该列的索引就无效了。

翻了下《高性能MySQL第二版》和《MySQL技术内幕——InnoDB存储引擎第2版》,并没有看到关于这个的介绍。但在本地试了下,null列是可以用到索引的,不管是单列索引还是联合索引,但仅限于is null,is not null是不走索引的。

后来在官方文档中找到了说明,如果某列字段中包含null,确实是可以使用索引的,地址:https://dev.mysql.com/doc/refman/5.7/en/is-null-optimization.html。

在mysql5.6和5.7下均可,存储引擎为InnoDB。

数据如下:

1. 单列索引

给name列建单列索引:

查询name为null的行:

查询name为'test0'或为null的行:

可以发现都可以用到索引。

2. 联合索引

给age和name添加联合索引:


查询age为14并且name为null的行:

可以发现同样用到了索引。

3. 其他

虽然MySQL可以在含有null的列上使用索引,但不代表null和其他数据在索引中是一样的。

不建议列上允许为空。最好限制not null,并设置一个默认值,比如0和''空字符串等,如果是datetime类型,可以设置成'1970-01-01 00:00:00'这样的特殊值。

对MySQL来说,null是一个特殊的值,Conceptually, NULL means “a missing unknown value” and it is treated somewhat differently from other values。比如:不能使用=,,>这样的运算符,对null做算术运算的结果都是null,count时不会包括null行等,null比空字符串需要更多的存储空间等。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。

您可能感兴趣的文章:
  • Mysql 索引该如何设计与优化
  • 浅谈mysql的索引设计原则以及常见索引的区别
  • 分享几道关于MySQL索引的重点面试题
  • 跳槽必备之你设计索引的原则是什么?怎么避免索引失效?

标签:昌都 北京 鄂尔多斯 黔西 梅河口 陕西 驻马店 荆门

巨人网络通讯声明:本文标题《MySQL中NULL对索引的影响深入讲解》,本文关键词  MySQL,中,NULL,对,索引,的,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《MySQL中NULL对索引的影响深入讲解》相关的同类信息!
  • 本页收集关于MySQL中NULL对索引的影响深入讲解的相关信息资讯供网民参考!
  • 推荐文章