zoukankan      html  css  js  c++  java
  • MySQL中count(1),count(*),count(col)的区别

    count(*)返回行数的时候不管列中的值是不是null,在MyISAM表中,count(*)被优化,因为在MyISAM表中,行数被额外存储了,所以会很快,但是这个时候不能有where条件。innodb不会做类似的优化,因为在进行事务管理的时候,并发事务可能会看到不同的列值。

    在MyISAM表中,如果第一列不是null值,那么count(1)被做了和count(*)一样的优化,count(col)就是根据列名检索非null的行,如果MyISAM知道col列非null,则count(col)会被优化成count(*)。

    InnoDB handles SELECT COUNT(*) and SELECT COUNT(1) operations in the same way. There is no performance difference.

  • 相关阅读:
    10.23
    四则运算(1)
    10.12
    10.22
    今日总结
    Java自学
    Java自学
    Java自学
    Java自学
    Java自学
  • 原文地址:https://www.cnblogs.com/zhangcaiwang/p/7299970.html
Copyright © 2011-2022 走看看