mysql中按组计算排除最新记录后其他记录和
问题:给定包含时间和类型的以下数据表:
create table c ( time timestamp, type varchar(255), num int ); insert into c values ('2023-01-01 00:00:00', 'a', 10), ('2023-01-01 00:00:00', 'b', 12), ('2023-01-02 00:00:00', 'a', 15), ('2023-01-02 00:00:00', 'b', 18), ('2023-01-03 00:00:00', 'a', 20), ('2023-01-03 00:00:00', 'b', 22);
如何写一个mysql查询,按type分组,计算排除最新一条记录后其余记录num值的总和?
解答:
SELECT t.type, SUM(t.num) FROM ( SELECT type, num, ROW_NUMBER() OVER (PARTITION BY type ORDER BY time DESC ) AS row_num FROM C ) t WHERE t.row_num != 1 GROUP BY t.type
此查询包含以下步骤:
以上就是MySQL 中如何按组计算排除最新记录后其他记录的数值总和?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号