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

 更新时间:2023年09月28日 10:07:12   作者: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。

总结

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

相关文章

  • MySQL5.6升级5.7时出现主从延迟问题排查过程

    MySQL5.6升级5.7时出现主从延迟问题排查过程

    这篇文章主要介绍了MySQL5.6升级5.7时出现主从延迟问题排查过程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • mysql的join查询和多次查询方式比较

    mysql的join查询和多次查询方式比较

    这篇文章主要介绍了mysql的join查询和多次查询方式的比较,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • MySQL用truncate命令快速清空一个数据库中的所有表

    MySQL用truncate命令快速清空一个数据库中的所有表

    这篇文章主要介绍了MySQL用truncate命令快速清空一个数据库中的所有表,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • Mysql错误Cannot find or open table x/x from the internal问题解决方法

    Mysql错误Cannot find or open table x/x from the internal问题解决方法

    这篇文章主要介绍了Mysql错误Cannot find or open table x/x from the internal问题解决方法,需要的朋友可以参考下
    2014-06-06
  • mysql 5.6 压缩包版安装方法

    mysql 5.6 压缩包版安装方法

    这篇文章主要为大家详细介绍了mysql 5.6 压缩包版安装方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-12-12
  • MySQL8安装Installer版的图文教程

    MySQL8安装Installer版的图文教程

    这篇文章主要介绍了MySQL8安装Installer版的教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • 解决mysql连接超时和mysql连接错误的问题

    解决mysql连接超时和mysql连接错误的问题

    这篇文章主要介绍了解决mysql连接超时和mysql连接错误的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • 利用Prometheus与Grafana对Mysql服务器的性能监控详解

    利用Prometheus与Grafana对Mysql服务器的性能监控详解

    Prometheus是源于 Google Borgmon的一个开源监控系统,用 Golang开发。被很多人称为下一代监控系统。Grafana是一个开源的图表可视化系统,简单说图表配置比较方便、生成的图表比较漂亮。下面就介绍了利用Prometheus与Grafana对Mysql服务器性能监控的方法。
    2017-03-03
  • MYSQL开发性能研究之批量插入数据的优化方法

    MYSQL开发性能研究之批量插入数据的优化方法

    在网上也看到过另外的几种方法,比如说预处理SQL,比如说批量提交。那么这些方法的性能到底如何?本文就会对这些方法做一个比较
    2017-07-07
  • MySQL数据库升级的一些

    MySQL数据库升级的一些"陷阱"

    这篇文章主要介绍了MySQL数据库升级需要注意的地方,帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-08-08

最新评论