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用truncate命令快速清空一个数据库中的所有表
这篇文章主要介绍了MySQL用truncate命令快速清空一个数据库中的所有表,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-11-11Mysql错误Cannot find or open table x/x from the internal问题解决方法
这篇文章主要介绍了Mysql错误Cannot find or open table x/x from the internal问题解决方法,需要的朋友可以参考下2014-06-06利用Prometheus与Grafana对Mysql服务器的性能监控详解
Prometheus是源于 Google Borgmon的一个开源监控系统,用 Golang开发。被很多人称为下一代监控系统。Grafana是一个开源的图表可视化系统,简单说图表配置比较方便、生成的图表比较漂亮。下面就介绍了利用Prometheus与Grafana对Mysql服务器性能监控的方法。2017-03-03
最新评论