您的位置:首页技术文章
文章详情页

mysql 数据几十万 CPU过高

浏览:58日期:2022-06-15 08:12:47

问题描述

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

问题解答

回答1:

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

回答2:

sql 语句 发一下。

回答3:

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

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

show table status where Name = ’your table name’

可以拿到近似的行数。

回答4:

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

相关文章: