• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    MySQL中NULL对索引的影响深入讲解

    前言

    看了很多博客,也听过很多人说,包括我们公司的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启动报错问题InnoDB:Unable to lock/ibdata1 error
    下一篇:简单了解mysql方言dialect
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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