文章详情页
mysql 数据几十万 CPU过高
浏览:119日期: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:这个可以用延迟关联查询(索引覆盖查询)
相关文章:
1. Docker for Mac 创建的dnsmasq容器连不上/不工作的问题2. docker安装后出现Cannot connect to the Docker daemon.3. mysql - 为什么where条件中or加索引不起作用?4. ios - 类似微博首页,一张图的时候是如何确定图大小的?5. Span标签6. javascript - 请教空白文本节点的问题7. django进行数据库的查询8. javascript - 子级的div是float浮动;怎么让子级的div的高度继承父级的高度9. javascript - 天猫首页首屏数据来源10. mysql - php 如何網址中出現該頁標題?
排行榜
