mysql求和 子查询_mysql – 对几个查询的结果进行求和,然后在...

该博客介绍了如何在MySQL中通过子查询对多个不同的数据表(pageview, upvote, attending)进行计数,然后对这些计数结果进行求和和排序。通过UNION ALL合并查询结果,并在外部查询中使用SUM函数进行总和计算,以找到最高总和的前5个event_id。同时,讨论了在JOIN操作中避免丢失行的问题以及在不同情况下调整计数值的方法。" 128482826,16806445,Django成绩管理系统与学情分析平台,"['Python', 'Django', '课程设计', 'Web开发', '成绩管理系统']
摘要由CSDN通过智能技术生成

这个问题留下了解释的空间.要UNION所有三个查询的结果行,然后选择具有最高“金额”的5行:

(SELECT event_id, count(*) AS amount

FROM pageview

GROUP BY event_id

ORDER BY pageviews DESC, rand()

LIMIT 1000)

UNION ALL

(SELECT event_id, count(*)

FROM upvote

GROUP BY event_id

ORDER BY upvotes DESC, rand()

LIMIT 1000)

UNION ALL

(SELECT event_id, count(*)

FROM attending

GROUP BY event_id

ORDER BY attendants DESC, rand()

LIMIT 1000)

ORDER BY 2 DESC

LIMIT 5;

To apply ORDER BY or LIMIT to an individual SELECT, place the clause

inside the parentheses that enclose the SELECT.

UNION ALL,因此不会删除重复项.

如果要为每个event_id添加计数,则此查询应执行此操作:

SELECT event_id, sum(amount) AS total

FROM (

(SELECT event_id, count(*) AS amount

FROM pageview

GROUP BY event_id

<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值