Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > MySql按照日期进行分组统计

MySql如何按照日期进行分组统计

作者:zhao_854093140

这篇文章主要介绍了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。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文