MySql按照日期进行分组统计

MySql按照日期进行分组统计

最近接到一个需求,就是按照日期进行统计数量,数据库表里有id(编号),date(日期),phone(手机号)

数据库

CREATE TABLE `tb_count`  (
  `id` int(20) NOT NULL AUTO_INCREMENT COMMENT '编号',
  `tiems` datetime(0) NOT NULL COMMENT '日期',
  `number` varchar(11) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '手机号',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 18 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

我的sql是这样的
这一条sql是查询所有的,可以按照这个方法进行分页查询,查询所有

SELECT COUNT(*) AS counts,DATE_FORMAT(tiems,"%Y年%m月%d日") AS dates FROM tb_count  GROUP BY DATE_FORMAT (tiems,"%Y年%m月%d日")

-- DATE_FORMAT();按照格式对某个日期操作,
-- tb_count 表名
-- period 日期
-- 整段代码的意思是:从tb_count表中 查询日期(period )(将日期按照"%Y年%m月"格式)并作为dates,统计数量(count(*)),按照日期分组 GROUP BY DATE_FORMAT(period ,"%Y年%m月")

如果是进行分页查询 我是做了一个封装,将count(数量)和period(时间)做了一个封装,做了一个实体类,技术有限,只能想到封装为一个对象

封装对象

@ApiModel(description = "Statis",value = "Statis")
public class Statis implements Serializable {
    //数量
    @ApiModelProperty(value = "",required = false)
    private int counts;
    //时间
    @ApiModelProperty(value = "",required = false)
    private String dates;

    public int getCounts() {
        return counts;
    }

    public void setCounts(int counts) {
        this.counts = counts;
    }
    public String getDates() {
        return dates;
    }
    public void setDates(String dates) {
        this.dates = dates;
    }
}

Service层

  /**
     * 分页查询
     * @param page 当前页
     * @param size 每页显示的条数
     * @return
     */
    Result findPage(int page,int size);

ServiceImpl Service层实现类

我这边用分页插件是PageInfo,需要传入一个page和size

  /**
     * 分页查询
     * @param page 当前页
     * @param size 每页显示的条数
     * @return
     */
    @Override
    public Result findPage(int page, int size) {
        try {
            //分页查询
            PageHelper.startPage(page, size);
            //查询所有
            List<Statis> statisList = countsMapper.findAll();
            PageInfo<Statis> pageInfo = new PageInfo<Statis>(statisList);
            return new Result(true,StatusCode.OK,"分页查询成功",pageInfo);
        }catch (Exception e){
            e.printStackTrace();
            return  new Result(false,StatusCode.ERROR,"分页查询失败");
        }

    }

Controller层


    /**
     * 分页查询
     * @param page 当前页
     * @param size 每页显示的条数
     * @return
     * @throws Exception
     */
    @GetMapping("/search/{page}/{size}")
    @ApiImplicitParams({
            @ApiImplicitParam(paramType = "path", name = "page", value = "当前页", required = true, dataType = "Integer"),
            @ApiImplicitParam(paramType = "path", name = "size", value = "每页显示条数", required = true, dataType = "Integer")
    })
    @ApiOperation(value = "日期分页查询",notes = "日期分页方法详情",tags = {"MemberController"})
    public Result findPage(@PathVariable int page,@PathVariable int size) throws Exception {
      return   countsService.findPage(page, size);
    }

最后就是测试了

在这里插入图片描述
这个需求不是很难,就是一个简单的分页查询而已,难点在于这个sql,今天的分享就到这来了.

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值