dongrong9938 2017-08-10 10:10
浏览 118
已采纳

创建INDEX以改善ORDER BY导致的慢执行时间

I have the following query in a PHP function. This gets called a number of times depending on a number of factors, but even if it is executed only 1 time it takes a long time.

SELECT  `date` as dateTo
FROM    table_name tbl
WHERE    `colA` = 223 and `colB` <> 1
ORDER BY `date` DESC
LIMIT 1

The database table has about 2 million records and the ORDER BY is slowing the execution time.

What is the best INDEX I could have in this scenario?

Would an index on date only be beneficial or would I have to include colA and colB?

-----

I ended up using this query,

SELECT  `ColA`,`date`, `ColB`
FROM  atm_status_log
WHERE  `ColA` = 223
HAVING  `ColB` <> 1
ORDER BY `date` DESC
LIMIT 1;

and this INDEX, INDEX(colA, colB, date)

  • 写回答

4条回答 默认 最新

  • douxi2011 2017-08-10 10:46
    关注

    You have to add a index on date, colA, colB. Please keep in mind the order off that index matters.

    ALTER TABLE table_name ADD KEY index_name (date, colA, colB); 
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line