mysql中的年,月,日统计以及日历表的实现
时间:2020-05-22
本文章向大家介绍mysql中的年,月,日统计以及日历表的实现,主要包括mysql中的年,月,日统计以及日历表的实现使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
日历表的实现
创建日历表脚本
首先,日历表的创建和数据的插入如果自己手写,确实麻烦的不行,但是刚刚说的前人的轮子也不是吃素的,如下脚本:
CREATE TABLE num (i int);-- 创建一个表用来储存0-9的数字
INSERT INTO num (i) VALUES (0), (1), (2), (3), (4), (5), (6), (7), (8), (9);-- 生成0-9的数字,方便以后计算时间
CREATE TABLE if not exists calendar(datelist date); -- 生成一个存储日期的表,datalist是字段名
-- 这里是生成并插入日期数据
INSERT INTO calendar(datelist) SELECT
adddate(
( -- 这里的起始日期,你可以换成当前日期
DATE_FORMAT("2018-1-1", '%Y-%m-%d')
),
numlist.id
) AS `date`
FROM
(
SELECT
n1.i + n10.i * 10 + n100.i * 100 + n1000.i * 1000+ n10000.i * 10000 AS id
FROM
num n1
CROSS JOIN num AS n10
CROSS JOIN num AS n100
CROSS JOIN num AS n1000
CROSS JOIN num AS n10000
) AS numlist;
按日期统计
SELECT
c.datelist as date,
COUNT(b.id) as count
FROM
calendar AS c
LEFT JOIN (
SELECT
*
FROM
driver -- 真正想统计的表名
WHERE
lnvalid = 2 -- 这个是查询条件,你们酌情写自己的
AND flag = 0 -- 这个是查询条件,你们酌情写自己的
) AS b ON c.datelist = DATE(b.create_time) -- 两个表的关联,因为我表中crate_time是年月日时分秒的,所以要格式化后相等
WHERE
c.datelist LIKE '2019-10%' -- 这个是查询某月的日期统计,在代码中这块应该是一个参数。我这里查询的2019年10月份的统计
GROUP BY
datelist -- 这个分组按照日期分组,再次声明这个是天的,如果月的这里会不同
ORDER BY
datelist -- 这个排序是因为之前一次测试有count的在上面,没有的在下面,日期没有顺序,所以我又升序排了下。
按月份统计
SELECT DATE_FORMAT(c.datelist, '%Y-%m') as date, -- 查询的是年-月,所以要格式处理 COUNT(b.id) as count FROM calendar AS c LEFT JOIN ( SELECT * FROM driver -- 真正想统计的表名 WHERE lnvalid = 2 -- 这个是查询条件,你们酌情写自己的 AND flag = 0 -- 这个是查询条件,你们酌情写自己的 ) AS b ON c.datelist = DATE(b.create_time) -- 两个表的关联,因为我表中crate_time是年月日时分秒的,所以要格式化后相等 WHERE c.datelist LIKE '2019%' -- 这个是查询某月的日期统计,在代码中这块应该是一个参数。我这里查询的2019年的统计 GROUP BY DATE_FORMAT(c.datelist, '%Y-%m')-- 这个分组按照月份分组的,因为datelist是年月日,所以要格式化处理成年月 ORDER BY datelist -- 这个排序是因为之前一次测试有count的在上面,没有的在下面,日期没有顺序,所以我又升序排了下。
按照年统计
SELECT
DATE_FORMAT(c.datelist, '%Y') as date, -- 查询的是年,所以要格式处理
COUNT(b.id) as count
FROM
calendar AS c
LEFT JOIN (
SELECT
*
FROM
base_driver -- 真正想统计的表名
WHERE
if_lnvalid = 2 -- 这个是查询条件,你们酌情写自己的
AND flag = 0 -- 这个是查询条件,你们酌情写自己的
) AS b ON c.datelist = DATE(b.create_time) -- 两个表的关联,因为我表中crate_time是年月日时分秒的,所以要格式化后相等
GROUP BY
DATE_FORMAT(c.datelist, '%Y')-- 这个分组按照月份分组的,因为datelist是年月日,所以要格式化处理成年
ORDER BY
datelist -- 这个排序是因为之前一次测试有count的在上面,没有的在下面,日期没有顺序,所以我又升序排了下。
原文地址:https://www.cnblogs.com/liangmm/p/12938597.html
- 局域网与互联网环境下MTU的快速确定方法
- 【4】通过简化的正则表达式处理字符串
- silverlight中的socket编程注意事项
- socket中的byte消息格式设计
- 在silverlight中利用socket发送图片或文件
- 多线程中的ManualResetEvent
- 进程与线程
- ASP.NET TreeView相关问题
- 温故而知新:WinForm/Silverlight多线程编程中如何更新UI控件的值
- ASP.Net Web Page深入探讨
- 用Design+Blend轻松制作环形文字
- 对asp.net响应事件的试验
- 为服务器控件加入客户端事件处理的几种方法
- 温故而知新:Delegate,Action,Func,匿名方法,匿名委托,事件
- MySQL 教程
- MySQL 安装
- MySQL 管理与配置
- MySQL PHP 语法
- MySQL 连接
- MySQL 创建数据库
- MySQL 删除数据库
- MySQL 选择数据库
- MySQL 数据类型
- MySQL 创建数据表
- MySQL 删除数据表
- MySQL 插入数据
- MySQL 查询数据
- MySQL where 子句
- MySQL UPDATE 查询
- MySQL DELETE 语句
- MySQL LIKE 子句
- mysql order by
- Mysql Join的使用
- MySQL NULL 值处理
- MySQL 正则表达式
- MySQL 事务
- MySQL ALTER命令
- MySQL 索引
- MySQL 临时表
- MySQL 复制表
- 查看MySQL 元数据
- MySQL 序列 AUTO_INCREMENT
- MySQL 处理重复数据
- MySQL 及 SQL 注入
- MySQL 导出数据
- MySQL 导入数据
- MYSQL 函数大全
- MySQL Group By 实例讲解
- MySQL Max()函数实例讲解
- mysql count函数实例
- MYSQL UNION和UNION ALL实例
- MySQL IN 用法
- MySQL between and 实例讲解
- meta生成器 —— 表单元素组件 meta表单代码meta的模板data变幻
- 不用写代码也能做表单 —— 加载meta即可 菜单表单加载json运行效果。ModelAbout
- 从0到1,手把手教你入门 etcd
- 数据结构:手把手带你了解 ”图“ 所有知识!(含DFS、BFS)
- 设计模式之单例模式
- AndroidStudio创建JNI 工程与调用
- Java 版植物大战僵尸思路和源码分享!
- 你好MyBatis 入门篇
- 你好MyBatis 中级篇
- 你好MyBatis 中高级篇
- Nginx反代理获取真实IP
- 你好MyBatis 高级篇
- redis实现分布式锁:他说,他的分布式锁,很润哦
- Python_字符串
- DBeaver链接ClickHouse