mysql - 获取每组前 X 天的收入

标签 mysql sql group-by where-clause

这是我的 table

CREATE TABLE financials ( 
id INT(6) UNSIGNED AUTO_INCREMENT PRIMARY KEY, 
CountryID VARCHAR(30) NOT NULL, 
ProductID VARCHAR(30) NOT NULL,  
Revenue INT NOT NULL, 
cost INT NOT NULL, 
reg_date TIMESTAMP 
); 


INSERT INTO `financials` (`id`, `CountryID`, `ProductID`, `Revenue`, `cost`, `reg_date`) VALUES 
( 1, 'Canada', 'Doe'   , 20,  5, '2010-01-31 12:01:01'), 
( 2, 'USA'   , 'Tyson' , 40, 15, '2010-02-14 12:01:01'), 
( 3, 'France', 'Keaton', 80, 25, '2010-03-25 12:01:01'),
( 4, 'France', 'Keaton',180, 45, '2010-04-24 12:01:01'),
( 5, 'France', 'Keaton', 30,  6, '2010-04-25 12:01:01'),
( 6, 'France', 'Emma'  , 15,  2, '2010-01-24 12:01:01'),
( 7, 'France', 'Emma'  , 60, 36, '2010-01-25 12:01:01'),
( 8, 'France', 'Lammy' ,130, 26, '2010-04-25 12:01:01'),
( 9, 'France', 'Louis' ,350, 12, '2010-04-25 12:01:01'), 
(10, 'France', 'Dennis',100,200, '2010-04-25 12:01:01'),
(11, 'USA'   , 'Zooey' , 70, 16, '2010-04-25 12:01:01'),
(12, 'France', 'Alex'  ,  2, 16, '2010-04-25 12:01:01'); 

对于每个产品和日期组合,我需要获取前 5 天的收入。例如,对于产品“Keaton”,最后一次购买是在 2010-04-25,它只会汇总 2010-04-20 到 2010-04-25 之间的收入,因此它将是 210。而对于“Emma” ,它将返回 75,因为它将对 2010-01-20 到 2010-01-25 之间的所有内容求和。

SELECT ProductID, sum(revenue), reg_date
  FROM financials f
Where reg_date in (
    SELECT reg_date
    FROM financials as t2
    WHERE t2.ProductID = f.productID
    ORDER BY reg_date
    LIMIT 5)

不幸的是,当我使用 https://sqltest.net/ 时或 http://sqlfiddle.com/它说不支持“LIMIT & IN/ALL/ANY/SOME subquery”。我的查询是否有效?

最佳答案

您的查询是正确的,但可能无法在 MySQL 中运行。 MySQL 对子查询使用 inlimit 有限制。

相反:

SELECT f.ProductID, SUM(f.revenue)
FROM financials f JOIN
     (SELECT ProductId, MAX(reg_date) as max_reg_date
      FROM financials
      GROUP BY ProductId
     ) ff
     ON f.ProductId = ff.ProductId and
        f.reg_date >= ff.max_reg_date - interval 5 day
GROUP BY f.ProductId;

编辑:

如果你想为每个产品和日期组合使用这个,那么你可以使用自连接或相关子查询:

SELECT f.*,
       (SELECT SUM(f2.revenue)
        FROM financials f2
        WHERE f2.ProductId = f.ProductId AND
              f2.reg_date <= f.reg_date AND
              f2.reg_date >= f.reg_date - interval 5 day
       ) as sum_five_preceding_days
FROM financials f;

关于mysql - 获取每组前 X 天的收入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48216279/

相关文章:

MySQL - 基于列值的连接?

php - MySQL无法执行

r - 为组 R 生成随机数

mysql - 在 MySql 中执行查询时与 only_full_group_by 相关的错误

mysql - 如何统计mysql中的json项

mysql - 将 native phpmyadmin 数据库移至 xampp

MySQL 替换字符串 SUM 然后总计

php - 搜索 csv 列并插入到 mysql

sql - 在 Oracle SQL 中创建并填充 Varray

python - 使用 groupby 和 last 拆分 Pandas Dataframe