sql时间相关查询

查询当天新增的条数

select * from t_report_info 
where to_days(create_time) = to_days(now());

查询指定时间新增的条数

select * from t_report_info 
where to_days(create_time) = to_days('2023-09-04');

查询30天内新增的条数

select 
date_format(create_time,'%Y-%m-%d') as evertday,
count(*) countNum
FROM t_user_info
GROUP BY evertday 
ORDER BY evertday DESC 
limit 30

查询近30天的数据

select * from t_user_login_record where date_sub(curdate(),interval 30 day) <= date(create_time)

查询本月

select * from t_user_login_record where 
date_format(create_time,'%Y%m') = date_format(curdate() , '%Y%m')

查询上个月

select * from t_user_info where 
period_diff(date_format(now(),'%Y%m') , date_format( create_time,'%Y%m' )) =1

查询本季度数据

select * from t_user_info where quarter(create_time)=quarter(now())

查询上季度数据

select * from t_user_info 
where 
QUARTER(create_time)=quarter(date_sub(now(),interval 1 quarter));

查询本年数据

select * from t_user_info where year(create_time) = year(now())

查询上年数据

select * from t_user_info 
where 
year(create_time)=year(date_sub(now(),interval 1 year))

按月分组

SELECT count(0) as count,DATE_FORMAT( create_time,'%Y-%m') as time 
FROM t_user_info  GROUP BY  time

查询当前这周的数据

select * from t_user_login_record 
where yearweek(date_format(create_time,'%Y-%m-%d')) = yearweek(now())

查询上周数据

select * from t_user_login_record 
where 
yearweek(date_format(create_time,'%Y-%m-%d')) = yearweek(now()) - 1

MySQL获取前 n 天,格式 (yyyy-MM-dd)

SELECT
	@cdate := date_add( @cdate, INTERVAL - 1 DAY ) AS dateStr 
FROM
	( SELECT @cdate := date_add( CURDATE(), INTERVAL + 1 DAY ) 
	FROM t_user_login_record) tmp1 
WHERE
	@cdate > DATE_SUB( CURDATE(), INTERVAL 30 DAY )
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值