日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
MySQL中按月統(tǒng)計并逐月累加統(tǒng)計值的幾種寫法

有時候,我們可能有這樣的場景,需要將銷量按月統(tǒng)計,并且按月逐月累加。寫慣了GROUP BY,按月統(tǒng)計倒是小case,但是逐月累加實現(xiàn)起來,要稍微麻煩一點。下面就整理幾種寫法,以備不時之需。

建表及模擬數(shù)據(jù)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25

-- 創(chuàng)建表
CREATE TABLE `sales` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `sales_date` date NOT NULL,
  `sales_amount` decimal(10,2) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

-- 插入模擬數(shù)據(jù)
INSERT INTO `sales` (`sales_date`, `sales_amount`) VALUES
('2023-01-01', 1500.00),
('2023-01-02', 1800.00),
('2023-01-05', 2200.00),
('2023-02-01', 1200.00),
('2023-02-03', 1800.00),
('2023-03-01', 2500.00),
('2023-03-05', 2800.00),
('2023-03-08', 3200.00),
('2023-04-01', 2100.00),
('2023-04-03', 1900.00),
('2023-04-05', 2600.00),
('2023-05-01', 3100.00),
('2023-05-02', 3400.00),
('2023-06-01', 3800.00),
('2023-06-06', 4200.00);

該表包含三個字段:id、sales_date、sales_amount。id為自增長主鍵,sales_date為銷售日期,sales_amount為銷售額。插入了15條模擬數(shù)據(jù),涵蓋了2023年1月至6月的銷售數(shù)據(jù)

一、自連接和子查詢

首先在內(nèi)部查詢中計算出每個月份的銷售總額和月份;接著在外部查詢中使用自連接和子查詢計算每個月份的累計銷售額

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

SELECT t1.month, t1.monthly_sales,
       SUM(t2.monthly_sales) AS cumulative_sales
FROM (
  SELECT DATE_FORMAT(sales_date, '%Y-%m') AS month,
         SUM(sales_amount) AS monthly_sales
  FROM sales
  GROUP BY month
) t1
JOIN (
  SELECT DATE_FORMAT(sales_date, '%Y-%m') AS month,
         SUM(sales_amount) AS monthly_sales
  FROM sales
  GROUP BY month
) t2 ON t1.month >= t2.month
GROUP BY t1.month;

二、子查詢

1
2
3
4
5
6
7
8
9
10
11
12
13

SELECT month, monthly_sales,
       (SELECT SUM(monthly_sales) 
        FROM (
          SELECT DATE_FORMAT(sales_date, '%Y-%m') AS month, SUM(sales_amount) AS monthly_sales
          FROM sales
          GROUP BY month
        ) t2
        WHERE t2.month <= t1.month) AS cumulative_sales
FROM (
  SELECT DATE_FORMAT(sales_date, '%Y-%m') AS month, SUM(sales_amount) AS monthly_sales
  FROM sales
  GROUP BY month
) t1;

此處使用了兩個子查詢,第一個子查詢用于獲取每個月份的總銷售額和月份,第二個子查詢用于計算累加值。在內(nèi)部子查詢中,通過<=操作符將當前月份以及之前所有月份的銷售額相加,從而得到累加值

三、子查詢+變量

1
2
3
4
5
6
7

SELECT month, monthly_sales, @cumulative := @cumulative + monthly_sales AS cumulative
FROM (
  SELECT DATE_FORMAT(sales_date, '%Y-%m') AS month, SUM(sales_amount) AS monthly_sales
  FROM sales
  GROUP BY month
) t1
CROSS JOIN (SELECT @cumulative := 0) t2;

此處使用了兩個子查詢,第一個子查詢用于獲取每個月份的總銷售額和月份,第二個子查詢用于初始化變量@cumulative。在外部查詢中,通過CROSS JOIN將兩個子查詢連接起來,并且使用變量@cumulative來計算累加值。

四、用戶變量和子查詢

在內(nèi)部查詢中先對銷售日期進行排序,然后使用用戶變量@cumulative來記錄每個月份的累加值。在最終的查詢結(jié)果中,輸出月份、當月銷售額以及累加值

1
2
3
4
5
6
7
8
9

SELECT month, monthly_sales,
       (@cumulative := @cumulative + monthly_sales) AS cumulative_sales
FROM (
  SELECT DATE_FORMAT(sales_date, '%Y-%m') AS month, 
         SUM(sales_amount) AS monthly_sales
  FROM sales
  GROUP BY month
  ORDER BY sales_date ASC
) t1, (SELECT @cumulative := 0) t2;

此處使用了兩個子查詢,第一個子查詢用于獲取每個月份的總銷售額和月份,并按銷售日期升序排序;第二個子查詢用于初始化用戶變量@cumulative。在外部查詢中,通過,連接兩個子查詢,并使用用戶變量@cumulative來計算每個月份的累加值。

五、表達式(CTE)和窗口函數(shù)

使用MySQL 8.0引入的通用表表達式(CTE)和窗口函數(shù),可以將累加值計算放在CTE中完成

1
2
3
4
5
6
7
8
9

WITH monthly_sales AS (
  SELECT DATE_FORMAT(sales_date, '%Y-%m') AS month, 
         SUM(sales_amount) AS monthly_sales
  FROM sales
  GROUP BY month
)
SELECT month, monthly_sales,
       SUM(monthly_sales) OVER (ORDER BY month) AS cumulative_sales
FROM monthly_sales;

此處使用了CTE來計算每個月份的總銷售額和月份,并在外部查詢中使用窗口函數(shù)SUM() OVER()對月份進行累加。

SUM() OVER()

使用MySQL 8.0引入的LATERAL關(guān)鍵字,以及OVER ORDER BY子句,按月份求和,再用SUM() OVER()進行累加,并分別輸出月份、當月銷售金額和累計銷售金額

1
2
3
4
5
6
7
8

SELECT  month, monthly_sales,
       SUM(monthly_sales) OVER (ORDER BY month) AS cumulative_sales
FROM (
  SELECT DATE_FORMAT(sales_date, '%Y-%m') AS month,
         SUM(sales_amount) AS monthly_sales
  FROM sales
  GROUP BY month
) t1;

此處使用LATERAL關(guān)鍵字和OVER ORDER BY子句對每個月份進行分組,并計算每個月份的銷售總額和sum() over()

目前大概就知道這幾種方式,各位有沒有其他更好的方法呢?


本文題目:MySQL中按月統(tǒng)計并逐月累加統(tǒng)計值的幾種寫法
瀏覽路徑:http://www.5511xx.com/article/cdhpegg.html