mysql 前10条 平均数_mysql – 每组最新N条记录的平均值

我当前的应用程序根据每个用户的所有记录计算点平均值:

SELECT `user_id`, AVG(`points`) AS pts

FROM `players`

WHERE `points` != 0

GROUP BY `user_id`

业务需求已更改,我需要根据每个用户的最近30条记录计算平均值.

相关表格具有以下结构:

桌子:球员;列:player_id,user_id,match_id,points

表:用户; columns:user_id

以下查询不起作用,但它确实演示了我尝试实现的逻辑.

SELECT @user_id := u.`id`, (

-- Calculate the average for last 30 records

SELECT AVG(plr.`points`)

FROM (

-- Select the last 30 records for evaluation

SELECT p.`points`

FROM `players` AS p

WHERE p.`user_id`=@user_id

ORDER BY `match_id` DESC

LIMIT 30

) AS plr

) AS avg_points

FROM `users` AS u

是否有一种相当有效的方法来根据每个用户的最新30条记录计算平均值?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值