如何优化这个MySQL查询

如何优化这个MySQL查询,第1张

概述当数据库很小时,这个查询工作正常,但是现在数据库中有数百万行,我意识到我应该先考虑优化它.它正在查看超过600,000行并且正在使用where;使用临时;使用filesort(导致执行时间为5-10秒).它正在使用字段'battle_type'上的索引.SELECT username, SUM( outcome ) AS wins, COUNT( * ) -

当数据库很小时,这个查询工作正常,但是现在数据库中有数百万行,我意识到我应该先考虑优化它.它正在查看超过600,000行并且正在使用where;使用临时;使用filesort(导致执行时间为5-10秒).它正在使用字段’battle_type’上的索引.

SELECT username,SUM( outcome ) AS wins,COUNT( * ) - SUM( outcome ) AS lossesFROM tblBattleHistoryWHERE battle_type =  '0' && outcome <  '2'GROUP BY usernameORDER BY wins DESC,losses ASC,username ASC liMIT 0,50@H_403_8@最佳答案首先要确保你有好的指数(正如其他人提到的那样).

但是,看起来您正在为网页创建某种排行榜.我的第一个问题是 – 你真的需要实时执行这个查询吗?您可以在数据库中创建一个表(或在users表中添加一个胜负列),并使用此查询的结果并定期刷新它吗?

总结

以上是内存溢出为你收集整理的如何优化这个MySQL查询全部内容,希望文章能够帮你解决如何优化这个MySQL查询所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1167126.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存