mysql 数据几十万 CPU过高

一个数据表数据有几十万的样子 在查询页面反复的时候 CPU特别高基本爆满
SQl语句
select count(*) from emp where catid <> 3 and cid =2; 用户做分页数量
select * from emp limit 1,10; 本页显示的

阅读 3.8k
3 个回答

你这个根本没有访问索引,直接读硬盘数据

InnoDB是没有直接保存表的数据总数的,select count(*) from emp;要扫一遍索引,反复查当然要耗CPU。

我的测试表有两千万数据,没缓存时count(*)要15秒,有缓存后也要3秒。

show table status where Name = 'your table name'

可以拿到近似的行数。

这个可以用延迟关联查询(索引覆盖查询)

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题