duan36000 2014-06-25 15:52
浏览 69
已采纳

MySQL搜索速度很慢,查询或索引不好?

We have a table in an application, which is VASTLY HUGE. Easily millions of rows.

The structure is basically as follows:

SERIES_ID | YEAR | DAY_SINCE_EPOCH | HOUR | MINUTE | VALUE

We have indexes on YEAR and DAY_SINCE_EPOCH.

The problem is that certain kind of queries are very slow, such as:

SELECT
 ...
WHERE
   SERIES_ID = 3 AND
   DAY_SINCE_EPOCH < 16000 AND
   YEAR = 2012
ORDER BY 
   DAY_SINCE_EPOCH DESC,
   HOUR DESC,
   MINUTE DESC
LIMIT 1

This takes about 10 seconds in a table with 2M rows, and well over 20 seconds in a table with 18M rows.

The intent is to find the last record of series 3, before day 16000. The YEAR=2012 is there to speed up the lookup.

So I was wondering, do we have the indexes set up right? Perhaps it'd be faster without the year index? Or with added SERIES_ID index or something like that?

Or just restructuring the query would help?

Any idea how to speed up the search will be welcome!

  • 写回答

2条回答 默认 最新

  • dongye9991 2014-06-25 15:55
    关注

    This index might help:

    > create index on your_table(series_id, day_since_epoch, year);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 RPA正常跑,cmd输入cookies跑不出来
  • ¥15 求帮我调试一下freefem代码
  • ¥15 matlab代码解决,怎么运行
  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。