首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在MySQL之外获取MySQL行的总和的技巧

在MySQL之外获取MySQL行的总和的技巧
EN

Stack Overflow用户
提问于 2011-08-26 13:04:49
回答 2查看 127关注 0票数 2

因此,我有以下查询:

代码语言:javascript
运行
复制
SELECT DISTINCT d.iID1 as 'id',
                      SUM(d.sum + d.count*r.lp)/sum(d.count) AS avgrat
                      FROM abcd i, abce r, abcf d
                      WHERE r.aID = 1 AND
                      d.iID1 <> r.rID  AND d.iID2 = r.rID GROUP BY d.iID1
                      ORDER BY avgrat LIMIT 50;

表中数以百万计的条目的问题是,SUM()GROUP BY会冻结query....is,有一种方法可以使用MySQL和/或perhaps立即执行(也许用PHP....but做求和,我该怎么做……)

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-08-26 13:11:33

直接回答这个问题:不,没有办法立即做任何事情。

如果您可以控制表的更新,或者添加相关记录的应用程序,那么您可以添加逻辑,在每次更新时使用sum、count和id更新另一个表。然后,修改后的查询以"sum表“为目标,简单地计算平均值。

票数 1
EN

Stack Overflow用户

发布于 2011-08-26 16:23:34

一种解决方案是使用源表上的触发器创建一个包含聚合值的汇总表,以使其保持最新。

您需要确定触发器的开销是否小于查询的开销。一些重要的因素包括:

源表的更新频率

聚合查询的运行频率。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7200204

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档