sql统计近三个月每月的销售额,统计近一周每天的销售额

统计近一周每天的销售额

select date_format(create_at,'%Y-%m-%d') as 'date', IFNULL(SUM(amount),0) as 'dayAmount'
from order_pay_trace
where create_at >= date(now()) - interval 6 day 
group by day(create_at);

统计近三个月每个月的销售额
这里在限制条件处先获得四个月的数据,因为最前面的月份不是满月的销售额,故舍去

select month(create_at) as 'month', IFNULL(SUM(amount),0) as 'monthAmount'
from order_pay_trace
where create_at >= date(now()) - interval 3 month AND date_format(create_at,'%Y-%m') <> date_format(date(now()) - interval 3 month,'%Y-%m')
group by month(create_at);

统计指定月份的销售额(此处以统计当前日期前一个月的销售额为例)

select date_format(date(now()) - interval 1 month,'%Y-%m') as 月份,IFNULL(SUM(amount),0) as 销售额
from order_orders
where date_format(create_at,'%Y-%m') = date_format(date(now()) - interval 1 month,'%Y-%m')

注意:上述sql语句也有一些bug,比方说如果使用第一条sql语句来查询当前时间内近七天的每天的销售额,因为group by分组是按照day(create_at)的日期来分的,若其中某一天没有创建订单,自然也不会有create_at,这样查出来的数据就会缺失这一天的销售额数据。
解决方案:在java代码中新建一个List<Map<String, Object>> newMapList = new ArrayList<>();集合,然后用java代码获取当前日期及其当前日期近一周内的所有日期,用java代码获得的日期和从sql中查出来的日期循环对比,若sql查出来的日期存在,那么将sql查出来的销售额赋值,若不存在默认销售额为0,最后将java代码中查出来的近七天的日期和对应的销售额存入一个map集合中一起加入到list集合中即可。

		List<Map<String, Object>> newMapList = new ArrayList<>();

        //获得近七天的日期和对应日期的日销售额
        List<Map<String, Object>> mapList = this.baseMapper.selectLastSevenDaysAmount();

        //处理日销售额格式 分转元
        for (Map<String, Object> map : mapList) {
            BigDecimal dayAmount = (BigDecimal) map.get("dayAmount");
            Integer intAmount = dayAmount.intValue();
            map.put("dayAmount", MoneyUtils.changeF2YDouble(intAmount));
        }

        //此处为了处理数据缺失导致的问题,比如某一天没有订单创建,那么sql语句中按照日期分组后就没有该日期这一组,自然也会缺失这一天的销售额
        for (int i = 0; i < 7; i++) {
            HashMap<String, Object> newMap = new HashMap<>();

            //获得近七天的日期date
            SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd");
            Calendar calendar = new GregorianCalendar();
            calendar.setTime(new Date());
            calendar.add(Calendar.DATE,-i);
            String date= sdf.format(calendar.getTime());

            Double dayAmount = 0.0;
            //将获得的日期和从数据库查询的日期作比较,若存才则将数据库得到的销售额赋值,若不存在则默认该天销售额为0.0
            for (Map<String, Object> map : mapList) {
                if (date.equals(map.get("date"))) {
                    dayAmount = (Double) map.get("dayAmount");
                }
            }
            newMap.put("date", date);
            newMap.put("dayAmount", dayAmount);

            newMapList.add(newMap);

        }

        return newMapList;
    }
  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,那我们假设有一个销售表 sales,其中包含以下字段: - id:销售记录的唯一标识符 - product_id:商品的唯一标识符 - sale_date:销售日期,格式为 YYYY-MM-DD - sale_amount:销售金额 我们可以使用如下 SQL 语句来查询每个商品的销售额同环比: ```sql SELECT DATE_FORMAT(s1.sale_date, '%Y-%m') AS month, SUM(s1.sale_amount) AS current_month_sales, SUM(s2.sale_amount) AS last_month_sales, SUM(s1.sale_amount) / SUM(s2.sale_amount) - 1 AS mom_growth_rate, SUM(s1.sale_amount) / SUM(s3.sale_amount) - 1 AS yoy_growth_rate FROM sales s1 LEFT JOIN sales s2 ON DATE_FORMAT(s1.sale_date, '%Y-%m') = DATE_FORMAT(DATE_SUB(s2.sale_date, INTERVAL 1 MONTH), '%Y-%m') AND s1.product_id = s2.product_id LEFT JOIN sales s3 ON DATE_FORMAT(s1.sale_date, '%Y-%m') = DATE_FORMAT(DATE_SUB(s3.sale_date, INTERVAL 1 YEAR), '%Y-%m') AND s1.product_id = s3.product_id GROUP BY DATE_FORMAT(s1.sale_date, '%Y-%m') ``` 这个 SQL 语句使用了三个子查询,分别对应当前、上和去年同期的销售数据。通过 LEFT JOIN 连接这三个子查询,我们可以得到每个销售额、上销售额、去年同期销售额,以及同环比增长率。其中,同比增长率计算方式为 `(当前销售额 / 去年同期销售额) - 1`,环比增长率计算方式为 `(当前销售额 / 上销售额) - 1`。最后,我们使用 DATE_FORMAT 函数将销售日期格式化为年,然后按份分组,即可得到每个的同环比销售数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值