貌似是因为用myisam引擎的表存储了总条数,如果没有where或者where恒为真(比如where
1),那么count(*)可以直接返回总条数。
2.
另外,很显然count(*)不是"计算所有的字段",显然mysql会把*解析成“一条数据”的意思。
sum(1)就是1这个数值,count(1)相当于第一列的名字,虽然统计行结果是一样的,从效率上还是推荐count。显然对于*和name知道主键列的直接指定会更好,不知道的话用星号也无妨。欢迎分享,转载请注明来源:内存溢出
貌似是因为用myisam引擎的表存储了总条数,如果没有where或者where恒为真(比如where
1),那么count(*)可以直接返回总条数。
2.
另外,很显然count(*)不是"计算所有的字段",显然mysql会把*解析成“一条数据”的意思。
sum(1)就是1这个数值,count(1)相当于第一列的名字,虽然统计行结果是一样的,从效率上还是推荐count。显然对于*和name知道主键列的直接指定会更好,不知道的话用星号也无妨。欢迎分享,转载请注明来源:内存溢出
评论列表(0条)