mysql面试题38:count(1)、count(*) 与 count(列名) 的区别_mysql

该文章专注于面试,面试只要回答关键点即可,不需要对框架有非常深入的回答,如果你想应付面试,是足够了,抓住关键点

面试官: count(1)、count(*) 与 count(列名) 的区别

当使用COUNT函数进行数据统计时,有三种常见的用法:COUNT(1)、COUNT(*)和COUNT(列名)。它们的区别如下:

  1. COUNT(1):在COUNT函数中使用1作为参数,表示统计行数。这种写法不会对具体的列进行操作,只会对行数进行计数。它会忽略列中的NULL值,只统计非NULL的行数。由于不涉及具体列的操作,因此效率较高。
  2. COUNT():在COUNT函数中使用作为参数,表示统计行数。与COUNT(1)类似,它也只关注行数而不涉及具体的列。与COUNT(1)不同的是,COUNT()会统计包括NULL值在内的所有行数,包括那些全部列值为NULL的行。由于需要考虑NULL值,因此相对于COUNT(1),COUNT()的性能可能稍低一些。
  3. COUNT(列名):在COUNT函数中使用具体的列名作为参数,表示统计该列的非NULL值的数量。COUNT(列名)会统计指定列中非NULL的行数,并返回结果。这种写法适用于需要统计特定列的情况。

关键点:COUNT(1)和COUNT()用于统计行数,COUNT(1)忽略NULL值,而COUNT()包括NULL值。COUNT(列名)用于统计指定列的非NULL值的数量。在实际使用中,应根据具体需求选择适当的写法。如果只关注行数而不涉及具体列的操作,常用COUNT(1)或COUNT(*);如果需要统计特定列的非NULL值数量,则使用COUNT(列名)。