count(*)和count(列)根本就是不等价的,count(*)是针对于全表的,而count(列)是针对于某一列的,如果此列值为空的话,count(列)是不会统计这一行的。
也就是说count(列)会用到索引,并且会过滤掉该列为null的那行。
而count(*)是全表扫描,并且只要某一条数据有一列不为null,那就会统计到这条数据。
count(1)可以理解为表里有一列数据都为1的列。
count(*),执行时会把星号翻译成字段的具体名字,效果也是一样的,不过多了一个翻译的动作,比固定值的方式效率稍微低一些。