MySQL查询连续的年、月、日、季度

本文提供了一系列的SQL查询示例,用于获取从特定日期开始的连续天数、月份、季度和年份。这些查询使用了`INTERVAL`和`TIMESTAMPDIFF`函数来计算和生成日期序列。此外,还展示了一个例子,展示了如何根据订单创建时间的年份和季度进行业务数据的分组分析。
摘要由CSDN通过智能技术生成

1、sql

-- 1、查询连续的天
SELECT
	date_format( date_sub( '2022-08-10', INTERVAL ( @i := @i - 1 ) DAY ), '%Y-%m-%d' ) AS times 
FROM
	mysql.help_topic
	JOIN ( SELECT @i := 1 ) c 
WHERE
	help_topic_id <= (
	TIMESTAMPDIFF( DAY, '2022-08-10', '2022-08-20' ));
	
-- 2、查询连续的月
		SELECT
	date_format( date_sub( '2022-08-10', INTERVAL ( @i := @i - 1 ) MONTH ), '%Y-%m' ) AS times 
FROM
	mysql.help_topic
	JOIN ( SELECT @i := 1 ) c 
WHERE
	help_topic_id <= (
	TIMESTAMPDIFF( MONTH, '2022-08-10', '2022-12-20' ));
	
-- 3、查询连续的季度
	SELECT
	CONCAT_WS("-",if(QUARTER( date_sub( '2022-08-10', INTERVAL (@i) QUARTER ))=4 && @i != 1,@j := @j + 1,@j),QUARTER( date_sub( '2022-08-10', INTERVAL ( @i := @i - 1 ) QUARTER ))) times
FROM
	mysql.help_topic
	JOIN ( SELECT @i := 1,@j := YEAR('2022-08-10')) c
WHERE
	help_topic_id <= (
	TIMESTAMPDIFF( QUARTER, '2022-08-10', '2023-12-20' ));
	
	-- 4、查询连续的年
		SELECT
	date_format( date_sub( '2022-08-10', INTERVAL ( @i := @i - 1 ) YEAR ), '%Y' ) AS times 
FROM
	mysql.help_topic
	JOIN ( SELECT @i := 1 ) c 
WHERE
	help_topic_id <= (
	TIMESTAMPDIFF( YEAR, '2022-08-10', '2023-12-20' ));

	
	-- 5、业务数据
	SELECT 
    CONCAT(YEAR(s.created_time),"-", QUARTER(s.created_time)) AS quarter 
FROM order_sell s  
GROUP BY CONCAT(YEAR(s.created_time),"-", QUARTER(s.created_time))
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值