免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3390 | 回复: 6

MySQL 5.5所有的慢查询都是因为找不到记录 [复制链接]

论坛徽章:
0
发表于 2015-11-12 18:11 |显示全部楼层
本帖最后由 disorderdev 于 2015-11-12 23:37 编辑

有一个表,数据量是1亿左右,存储引擎是MYISAM,数据大小是20G,table如下:
  1.     create table User {
  2.         user_id int primary key auto_increment,
  3.         user_email varchar(50) unique,
  4.         ...//no more than 20 columns
  5.     }  ENGINE=MyISAM
复制代码
查看了一下慢查询,近期所有的都是有以下一个语句导致的:
  1. select user_id, .... from User where user_email=?
复制代码
当给一个已经存在的mail时,很快就能返回结果,但如果给一个email不存在的,就好很慢,有时会超过2s。

请问这是什么原因?

会是因为运行时间太长了么(uptime>3年)?运行analyze table 会有帮助么?analyze table需要多长时间能完成?
还是因为找不到记录的时候是执行的全表扫描,磁盘比较慢?但即使是全表扫描,也应该用index吧?

求职 : Linux运维
论坛徽章:
203
拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:57:092015小元宵徽章
日期:2015-03-06 15:58:182015年亚洲杯之约旦
日期:2015-04-05 20:08:292015年亚洲杯之澳大利亚
日期:2015-04-09 09:25:552015年亚洲杯之约旦
日期:2015-04-10 17:34:102015年亚洲杯之巴勒斯坦
日期:2015-04-10 17:35:342015年亚洲杯之日本
日期:2015-04-16 16:28:552015年亚洲杯纪念徽章
日期:2015-04-27 23:29:17操作系统版块每日发帖之星
日期:2015-06-06 22:20:00操作系统版块每日发帖之星
日期:2015-06-09 22:20:00
发表于 2015-11-12 21:46 |显示全部楼层
表里面一条记录都没有?

论坛徽章:
0
发表于 2015-11-12 23:38 |显示全部楼层
回复 2# lyhabc

我描述错误,修改了一下。
就是搜索存在的记录,速度没问题,但如果是不存在的记录,就好很慢
   

求职 : Linux运维
论坛徽章:
203
拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:57:092015小元宵徽章
日期:2015-03-06 15:58:182015年亚洲杯之约旦
日期:2015-04-05 20:08:292015年亚洲杯之澳大利亚
日期:2015-04-09 09:25:552015年亚洲杯之约旦
日期:2015-04-10 17:34:102015年亚洲杯之巴勒斯坦
日期:2015-04-10 17:35:342015年亚洲杯之日本
日期:2015-04-16 16:28:552015年亚洲杯纪念徽章
日期:2015-04-27 23:29:17操作系统版块每日发帖之星
日期:2015-06-06 22:20:00操作系统版块每日发帖之星
日期:2015-06-09 22:20:00
发表于 2015-11-13 07:56 |显示全部楼层
当然了,要全表扫描

论坛徽章:
0
发表于 2015-11-13 09:47 |显示全部楼层
全表扫描也不需要这么慢吧

论坛徽章:
0
发表于 2015-11-16 17:38 |显示全部楼层
这种叫空查询,很费资源的。如果多的话,要在前端做缓存拦截掉。

论坛徽章:
0
发表于 2015-11-16 21:10 |显示全部楼层
空查询,学习了,有什么具体的优化方案么?因为在前端做缓存拦截的也需要在数据库有插入数据的时候去删除响应的缓存,如果实时性要求比较高的话,这个也不太好做。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP