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。

总结

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

相关文章

  • 关于Mysql提高SQL性能的技巧(必看)

    关于Mysql提高SQL性能的技巧(必看)

    这篇文章主要介绍了关于Mysql提高SQL性能的技巧(必看),SQL查询的性能直接影响系统的响应时间,优化SQL可以减少查询的执行时间,提高系统的响应速度,提升用户体验,本文就来详细讲解一下如何优化SQL性能
    2023-07-07
  • 在centOS 7安装mysql 5.7的详细教程

    在centOS 7安装mysql 5.7的详细教程

    这篇文章主要介绍了在centOS 7安装mysql 5.7的详细教程,非常不错,具有参考借鉴价值,需要的朋友参考下吧
    2016-12-12
  • 微信昵称带符号导致插入MySQL数据库时出错的解决方案

    微信昵称带符号导致插入MySQL数据库时出错的解决方案

    Mysql的utf8编码最多3个字节,而Emoji表情或者某些特殊字符是4个字节,所以会导致带有表情的昵称插入数据库时出错,下面给大家分享下解决方案,需要的朋友参考下吧
    2016-12-12
  • 查看当前mysql使用频繁的sql语句(详解)

    查看当前mysql使用频繁的sql语句(详解)

    下面小编就为大家带来一篇查看当前mysql使用频繁的sql语句(详解)。小编觉的挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-03-03
  • MySQL存储引擎总结

    MySQL存储引擎总结

    这篇文章主要介绍了MySQL存储引擎总结,本文讲解了什么是存储引擎、MyISAM、InnoDB、MEMORY、MERGE等内容,需要的朋友可以参考下
    2014-09-09
  • mysql增加新用户无法登陆解决方法

    mysql增加新用户无法登陆解决方法

    在使用mysql增加新用户之后,发现新增的用户无法登陆,一时束手无策,网上搜集整理了一下,晒出来和大家分享一下,希望可以帮助你们
    2012-11-11
  • Mysql中的事务是什么如何使用

    Mysql中的事务是什么如何使用

    事务是逻辑上的一组操作,组成这组操作的各个单元,要不全都成功要不全都失败,这个特性就是事务,下面为大家介绍下Mysql中的事务的具体使用
    2013-12-12
  • mysql回表查询是什么,回表查询的使用

    mysql回表查询是什么,回表查询的使用

    这篇文章主要介绍了mysql回表查询是什么,回表查询的使用方式,具有很好的参考价值,希望对大家有所帮助。
    2022-11-11
  • centos7通过yum安装mysql的方法

    centos7通过yum安装mysql的方法

    这篇文章主要介绍了centos7通过yum安装mysql的方法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-11-11
  • MySQL thread_stack连接线程的优化

    MySQL thread_stack连接线程的优化

    当有新的连接请求时,MySQL首先会检查Thread Cache中是否存在空闲连接线程,如果存在则取出来直接使用,如果没有空闲连接线程,才创建新的连接线程
    2017-04-04

最新评论