mysql查询一周内数据并分组_mysql 统计本周7天的数据并分组

今天写到项目的一个数据展示模块,最终要呈现的效果是用柱状图显示本周七天的访客数量,所以要给前端本周7天的数据

比如今天是周二(实际上也是),我们要给前端周一周二的数据,后面周三到周日因为还没到,数据置0

在网上找了一些相关信息,都是用sql语句直接查询最近七天的数据的方法,这样导致一个问题,我们再假设今天是周二,那么统计的就是上周二到今天的数据,然而我实际上并不需要上周的数据

这里说一下我自己的解决方法,首先我们了解一下mysql的DATEDIFF方法,它会返回两个date数据之间的天数,比如DATEDIFF(‘2019-8-13‘ , ‘2019-8-14‘),返回的结果是1

于是我们先写一个函数

@Select("SELECT count(id) FROM strange_record WHERE DATEDIFF( date_format( now( ) , ‘%Y-%m-%d‘ ) , date_format( time, ‘%Y-%m-%d‘ ) ) = #{day}")int getStrangeNumBeforeSomeDays(int day);

如果参数day=1,函数将返回1天前的数据统计值

然后我们获取今天是周几

public static intgetWeekday(){

Date today= newDate();

Calendar c=Calendar.getInstance();

c.setTime(today);int weekday=c.get(Calendar.DAY_OF_WEEK);if(weekday==1)return 7;else return weekda

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值