MySQL里的累计求和

在MySQL中,你可以使用SUM()函数来进行累计求和。如果你想要对一个列进行累计求和,可以使用OVER()子句与ORDER BY子句结合,进行窗口函数的操作。

以下是一个简单的例子,假设我们有一个名为sales的表,它有两个列:id和amount。我们想要得到每一行的累计求和值。

sum(字段名1) over(partition by 字段名2 order by 字段名3 asc/desc) 

--按照字段1进行累积求和
-- 按照字段2 进行分组
-- 在组内按照字段3进行排序

1.根据学号排序,对学生的成绩进行累积求和:

SELECT *,
       SUM(grade) OVER(ORDER BY stu_no) AS '累积求和'
FROM v_info

在这里插入图片描述
2.按照课程号分组,然后根据学号对成绩进行累积求和

SELECT *,
       SUM(grade) OVER(PARTITION BY c_no ORDER BY stu_no) AS '累积求和'
FROM v_info;

在这里插入图片描述
tips:一定要选择根据学号排序,要不然得出来的是最终的累积求和结果,如下图:

SELECT *,
       SUM(grade) OVER(PARTITION BY c_no) AS '累积求和'
FROM v_info;

在这里插入图片描述

相关推荐

  1. mysql分组求和后再求和

    2024-07-15 11:34:03       26 阅读
  2. 为什么写进MySQL数据顺序乱了?

    2024-07-15 11:34:03       60 阅读
  3. SQL server 按年按月进行累计值统计

    2024-07-15 11:34:03       33 阅读
  4. C语言求解最大公约数(欧几得算法应用)

    2024-07-15 11:34:03       29 阅读
  5. 求和...

    2024-07-15 11:34:03       43 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-15 11:34:03       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-15 11:34:03       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-15 11:34:03       58 阅读
  4. Python语言-面向对象

    2024-07-15 11:34:03       69 阅读

热门阅读

  1. CSS变换

    CSS变换

    2024-07-15 11:34:03      18 阅读
  2. Jupyter Lab 常用插件

    2024-07-15 11:34:03       25 阅读
  3. Elasticsearch集群健康检查与监控

    2024-07-15 11:34:03       24 阅读
  4. 数字化工厂八大核心应用场景

    2024-07-15 11:34:03       20 阅读
  5. 云原生存储解决方案

    2024-07-15 11:34:03       20 阅读
  6. 【LeetCode】最小栈

    2024-07-15 11:34:03       23 阅读
  7. Ionic 加载动画

    2024-07-15 11:34:03       20 阅读
  8. Yolo,输出的参数的含义

    2024-07-15 11:34:03       28 阅读