*
)、count(字段) 等。*
) 效率最差?*
) 是效率最差的,因为认知上 selete * from t
会读取所有表中的字段,所以凡是带有 *
字符的就觉得会读取表中所有的字段,当时网上有很多博客也这么说。data:image/s3,"s3://crabby-images/8d5c2/8d5c2ad112d164a642ad13dbf2adaaee61d6bb2f" alt=""
哪种 count 性能最好?
哪种 count 性能最好?
data:image/s3,"s3://crabby-images/27887/27887ef33d426bc35a7cf0adda0aa1fd413bb6b0" alt=""
count() 是什么?
count(主键字段) 执行过程是怎样的?
select count(id) from t_order;
data:image/s3,"s3://crabby-images/ee3fc/ee3fcfe7e79265fd16a31b398a33a3ae995435d0" alt=""
data:image/s3,"s3://crabby-images/9bb8d/9bb8db950dd51eccb7407130b986d958db972390" alt=""
count(1) 执行过程是怎样的?
data:image/s3,"s3://crabby-images/02ea2/02ea2dfad083d32569bbfc7fe6a488f7a1d8e3c1" alt=""
data:image/s3,"s3://crabby-images/f7342/f7342325121d8972a503123a423d8933f4fab77e" alt=""
count(*) 执行过程是怎样的?
*
这个字符的时候,是不是大家觉得是读取记录中的所有字段值?selete *
这条语句来说是这个意思,但是在 count(*) 中并不是这个意思。*
) 其实等于 count(0
),也就是说,当你使用 count(*
) 时,MySQL 会将 *
参数转化为参数 0 来处理。data:image/s3,"s3://crabby-images/cc6b0/cc6b034bf67baed3158cfa3aa01f165fa9f716a9" alt=""
*
) and SELECT COUNT(1
) operations in the same way. There is no performance difference.*
)和 SELECT COUNT(1
)操作,没有性能差异。count(字段) 执行过程是怎样的?
select count(name) from t_order;
data:image/s3,"s3://crabby-images/31b6e/31b6ee178f25d562f16409e053a0bfae5a4f5d9b" alt=""
小结
为什么要通过遍历的方式来计数?
data:image/s3,"s3://crabby-images/23e01/23e01d8f125eb5165da3152d43b7106e08e122ca" alt=""
如何优化 count(*)?
select count(*) from t_order
要花费差不多 5 秒!data:image/s3,"s3://crabby-images/07f7f/07f7f14388895fa2d1fca7593aa076f445114453" alt=""
data:image/s3,"s3://crabby-images/e66e7/e66e7aec513f51d59b7d9fd9e5352abc25704682" alt=""
data:image/s3,"s3://crabby-images/070b5/070b5e8c4e85ea0854b7edd2300c4f239fb56f81" alt=""
0 条评论