mysql统计天、周、月、季度、半年、年
- 之前在网上搜索按时间统计,发现不是很全 ,接着别人的思路进行延伸下,
- mysql统计天、周、月、季度、半年、年
- 前期工作创建辅助表
CREATE TABLE num (i INT);
INSERT INTO num (i) VALUES (0),(1),(2),(3),(4),(5),(6),(7),(8),(9); - 创建要查询的表
CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`username` varchar(32) NOT NULL COMMENT '用户名称',
`sex` char(1) DEFAULT NULL COMMENT '性别',
`address` varchar(256) DEFAULT NULL COMMENT '地址',
`create_time` varchar(100) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8; -- ----------------------------
-- Records of user
-- ----------------------------
INSERT INTO `user` VALUES ('', '小南', '男', '湖南湘潭', '2019-07-01');
INSERT INTO `user` VALUES ('', '小谭', '男', '湖南湘潭', '2019-07-02');
INSERT INTO `user` VALUES ('', '小梅', '女', '广东梅县', '2019-07-01');
INSERT INTO `user` VALUES ('', '小仪', '女', '四川仪陇', '2019-05-10');
INSERT INTO `user` VALUES ('', '小蓝', '女', '上海嘉定', '2019-11-11');
INSERT INTO `user` VALUES ('', '小苍', '男', '湖南湘潭', '2018-06-01');
INSERT INTO `user` VALUES ('', '小萨', '男', '湖南湘潭', '2018-01-02');
INSERT INTO `user` VALUES ('', '小静', '女', '广东梅县', '2018-06-01');
INSERT INTO `user` VALUES ('', '大幂幂', '女', '四川仪陇', '2019-03-10');
INSERT INTO `user` VALUES ('', '宋小宝', '女', '上海嘉定', '2019-05-11');
按天统计
SELECT
temp.date,
COALESCE (u.unmber, 0) 'number'
FROM
(
SELECT
adddate('2019-07-01', numlist.id) AS 'date'
FROM
(
SELECT
n1.i + n10.i * 10 + n100.i * 100 AS id
FROM
num n1
CROSS JOIN num AS n10
CROSS JOIN num AS n100
) AS numlist
WHERE
adddate('2019-07-01', numlist.id) < date_add('2019-07-05',INTERVAL 1 DAY)
) temp
LEFT JOIN (
SELECT
LEFT (create_time, 10) AS udate,
count(create_time) unmber
FROM
user
WHERE
1=1
GROUP BY
udate
) u ON temp.date = u.udate
ORDER BY
temp.date;

按周统计
SELECT
temp.monthWeek,
COALESCE (plan.number, 0) 'number'
FROM
(
SELECT
YEARWEEK(
adddate('2019-07-01', INTERVAL numlist.id WEEK),1 ) AS 'date',
CONCAT(
MONTH (date_format('2019-07-01', '%Y-%m-%d')),'月第', numlist.id + 1,'周') AS 'monthWeek'
FROM
(
SELECT
*
FROM
(
SELECT
n1.i + n10.i * 10 AS id
FROM
num n1
CROSS JOIN num AS n10
) a
WHERE
a.id <= 11
) AS numlist
WHERE
adddate('2019-07-01',INTERVAL numlist.id WEEK ) <= '2019-07-31'
) temp
LEFT JOIN (
SELECT
YEARWEEK( date_format(create_time, '%Y-%m-%d'), 1) date,
count( YEARWEEK(date_format(create_time, '%Y-%m-%d'),1 ) ) number
FROM
USER
WHERE
1 = 1
AND create_time >= '2019-07-01'
AND create_time <= '2019-07-31'
GROUP BY
YEARWEEK(
date_format(create_time, '%Y-%m-%d'),
1
)
) plan ON temp.date = plan.date;

按月统计
SELECT
LEFT (temp.date, 7) monthStr,
COALESCE (u.unmber, 0) 'number'
FROM
(
SELECT
adddate('2019-01-01',INTERVAL numlist.id MONTH ) AS 'date'
FROM
(
SELECT
*
FROM
(
SELECT
n1.i + n10.i * 10 AS id
FROM
num n1
CROSS JOIN num AS n10
) a
WHERE
a.id <= 11
) AS numlist
WHERE
adddate('2019-01-01',INTERVAL numlist.id MONTH) <= '2019-12-3'
) temp
LEFT JOIN (
SELECT
LEFT (create_time, 7) AS udate,
count(create_time) unmber
FROM
user
WHERE
1=1
GROUP BY
udate
) u ON LEFT (temp.date, 7) = u.udate
ORDER BY
temp.date
按季度统计
SELECT
temp.monthWeek,
COALESCE(plan.number, 0) 'number'
FROM
(
SELECT
QUARTER(adddate('2019-01-01', INTERVAL numlist.id QUARTER )) AS 'date',
CONCAT(year(date_format('2019-01-01','%Y-%m-%d')), '年第', numlist.id +1, '季度') AS 'monthWeek'
FROM
(
SELECT
*
FROM
(
SELECT
n1.i + n10.i * 10 AS id
FROM
num n1
CROSS JOIN num AS n10
) a
WHERE
a.id <= 11
) AS numlist
WHERE
adddate('2019-01-01',INTERVAL numlist.id QUARTER) <= '2019-12-31'
) temp
LEFT JOIN (
SELECT QUARTER(date_format(create_time,'%Y-%m-%d')) date,
count(QUARTER(date_format(create_time,'%Y-%m-%d'))) number
FROM user
where 1=1
and create_time >= '2019-01-01'
and create_time <= '2019-12-31'
group by QUARTER(date_format(create_time,'%Y-%m-%d'))
) plan
on temp.date = plan.date

按半年统计
SELECT
bannian 'content',
COALESCE (u.unmber, 0) 'number'
FROM
(
SELECT
adddate( '2018-01-01',INTERVAL numlist.id MONTH) AS 'date',
case DATE_FORMAT(adddate( '2018-01-01',INTERVAL numlist.id MONTH),'%c')
when 7 then '下半年'
when 8 then '下半年'
when 9 then '下半年'
when 10 then '下半年'
when 11 then '下半年'
when 12 then '下半年'
else '上半年' end
as bannian
FROM
(
SELECT * FROM(
SELECT
n1.i + n10.i * 10 AS id
FROM
num n1
CROSS JOIN num AS n10
) a
WHERE a.id <= 11
) AS numlist
WHERE
adddate('2018-01-01',INTERVAL numlist.id MONTH) <= '2018-12-31'
GROUP BY bannian
) temp
LEFT JOIN (
SELECT
case DATE_FORMAT(create_time,'%c')
when 7 then '下半年'
when 8 then '下半年'
when 9 then '下半年'
when 10 then '下半年'
when 11 then '下半年'
when 12 then '下半年'
else '上半年' end as udate,
count(create_time) unmber
FROM user
WHERE 1=1
and date_format(create_time,'%Y-%m-%d') >='2018-01-01'
and date_format(create_time,'%Y-%m-%d') <= '2018-12-31'
GROUP BY udate
) u ON bannian = u.udate ORDER BY bannian asc;

按年统计(近五年)
SELECT
COALESCE(plan.number, 0) 'number',
temp.date fiveYear
FROM
(
SELECT
Year(adddate('2015-01-01', INTERVAL numlist.id Year )) AS 'date'
FROM
(
SELECT
*
FROM
(
SELECT
n1.i + n10.i * 10 AS id
FROM
num n1
CROSS JOIN num AS n10
) a
WHERE
a.id <= 11
) AS numlist
WHERE
adddate('2015-01-01',INTERVAL numlist.id Year) <= '2019-12-31'
) temp
LEFT JOIN (
SELECT Year(date_format(create_time,'%Y-%m-%d')) date,
count(Year(date_format(create_time,'%Y-%m-%d'))) number
FROM user
where 1=1
group by year(date_format(create_time,'%Y-%m-%d'))
) plan
on temp.date = plan.date
order by temp.date asc
mysql统计天、周、月、季度、半年、年的更多相关文章
- mysql按日/周/月统计
一.mysql按日统计 ) count ' and start_time > '2017-06-28' group by days; 二.mysql按周统计 ) ' group by weeks ...
- java获取当前时间的年周月季度等的开始结束时间
import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; /** * Created b ...
- MySql查询日周月
常用计算日期的函数 日 date(日期) = CURDATE() 自然周 YEARWEEK(date_format(日期,'%Y-%m-%d') , 1) = YEARWEEK(now() , 1) ...
- mysql 查询,天,周,月等写法
1.查询当天的数据 select * from 表名 where TO_DAYS(时间字段)=TO_DAYS(NOW()); 2.查询当周的数据 select * from 表名 where YEAR ...
- mysql 时间戳 按周、日、月 统计方法 附 date格式
create_time时间戳格式 SELECT FROM_UNIXTIME(create_time,'%Y%u') weeks,COUNT(id) COUNT FROM role GROUP BY w ...
- mysql中增加某一时间段内的时间数据(包含:时间、年、月、日、第几周、季度)
创建表dim_date: create table `dim_date` ( `year` int (20), `month` int (20), `day` int (20), `week` int ...
- mysql如何按周统计数据?
转自:https://www.cnblogs.com/wanghetao/p/3920124.html MySql 按周/月/日统计数据的方法 知识关键词:DATE_FORMAT select DA ...
- pg按日,周,月进行数据统计
pg数据库按周,月统计数据 SELECT date_trunc('WEEK', insert_time) as insertDate, SUM(data_increment) as dataTotal ...
- Java统计用户年/月/周/日网站访问量
一:准备工作,引入相关依赖: 二:运行效果图: 下一次访问 三:具体代码如下 (1):CountObjectInfo.java package cn.csrc.base.count; import ...
随机推荐
- python_day03
今日所学内容 1.函数部分: #函数的三种定义方式#1.无参函数:不需要外部传入的参数#2.有参函数:需要接受外部传入的参数#3.空函数:def func(): pass#pass代表说明都不用做# ...
- C# 未在本地计算机上注册“Microsoft.Jet.OLEDB.4.0”
“Microsoft.Jet.OLEDB.4.0” 是数据库接口驱动,用来连接数据库的,一般多用于连Access和Excel.我在在winform开发时,在本地运行没有问题,可是部署到另一台服务器上就 ...
- PHP 模板引擎
PHP模板引擎的由来 ● 为了解决当时混合开发WEB应用出现的一系列问题:代码难维护,代码不可重用,程序员要求知识广等问题 ● 实现后端与前端不完全分离,开发与美工可以分工合作,提高效率 PHP模板引 ...
- python CGI编程---Apache服务安装(2)
一.下载Apache 下载地址:https://www.apachehaus.com/cgi-bin/download.plx 我这里下载第一个,我电脑是window的64位. 下载完成后,解压到 我 ...
- Flutter学习笔记(30)--Android原生与Flutter混编
如需转载,请注明出处:Flutter学习笔记(30)--Android原生与Flutter混编 这篇文章旨在学习如何在现有的Android原生项目上集成Flutter,实现Android与Flutte ...
- K8s 集群节点在线率达到 99.9% 以上,扩容效率提升 50%,我们做了这 3 个深度改造
点击下载<不一样的 双11 技术:阿里巴巴经济体云原生实践> 本文节选自<不一样的 双11 技术:阿里巴巴经济体云原生实践>一书,点击上方图片即可下载! 作者 | 张振(守辰) ...
- 【2018寒假集训 Day1】【位运算】桐桐的运输方案
桐桐的运输方案(transp) [问题描述] 桐桐有 N 件货物需要运送到目的地,它们的重量和价值分别记为: 重量:W1,W2,…,Wn: 价值:V1,V2,…,Vn: 已知某辆货车的最大载货量为 X ...
- [ASP.NET Core 3框架揭秘] 异步线程无法使用IServiceProvider?
标题反映的是上周五一个同事咨询我的问题,我觉得这是一个很好的问题.这个问题有助于我们深入理解依赖注入框架在ASP.NET Core中的应用,以及服务实例的生命周期. 一.问题重现 我们通过一个简单的实 ...
- Requests小技巧
- SDWebImage学习之 NSCache
1.使用SDWebImage的好处 1.异步下载(避免主线程卡死) 2.做好图片缓存(这样就不需要每次都加载网络图片) 3.解决了循环利用的问题 很容易造成内存警告
