starrocks 2.5版本日期递增,实现对应序号

select DATE_FORMAT(date_add('2024-08-05',(unnest - 1)),'%Y-%m-%d') date_time,'N' enable, unnest seq

from

(select array_cum_sum(cast(split(lpad('1',(days_diff('2024-08-27','2024-08-05')*2)-1,'1;'),';') as array<int>)) as array_list

) t ,unnest(array_list)

在starrocks 2.5版本中没有像3版本那么多函数,需要实现日期生成日期和对应的序号

sql代码解说:

  1. 计算两个日期之间的天数差:`days_diff('2024-08-27', '2024-08-05')`,这里计算的是从2024年8月5日到2024年8月27日的天数差。

  2. 生成一个由1组成的字符串,长度为天数差的两倍减1:`lpad('1',(days_diff('2024-08-27','2024-08-05')*2)-1,'1')`。这个字符串将用于下一步的拆分。因为还要生成对应数的字符,所以*2

  3. 将生成的字符串按分号`;`进行拆分,形成一个整型数组:`cast(split(lpad('1',(days_diff('2024-08-27','2024-08-05')*2)-1,'1;'),';') as array<int>)`。

  4. 计算数组的累积和:`array_cum_sum(...)`。这个函数会返回一个新数组,其中每个元素是原数组对应位置之前所有元素的和。

  5. 从子查询中选取累积和数组,并通过`unnest`函数将其展开成多行,每行包含数组中的一个元素及其索引。

  6. 对于每个展开的元素,计算一个新的日期:`DATE_FORMAT(date_add('2024-08-05',(unnest - 1)),'%Y-%m-%d')`。这里是将2024年8月5日加上索引减1的天数,然后格式化为'YYYY-MM-DD'格式。

  7. 选择计算出的日期、一个固定的字符串'N'作为`enable`字段,以及展开的数组元素的索引作为`seq`字段。

这段SQL的目的是生成一个日期序列,从2024年8月5日开始,每天递增,直到2024年8月27日,并为每个日期生成一行记录,包含日期、一个标志字段`enable`(这里始终为'N')和序列号`seq`。

相关推荐
柒.梧.7 分钟前
Java位运算详解:原理、用法及实战场景(面试重点)
开发语言·数据库·python
callJJ11 分钟前
深入浅出 MVCC —— 从零理解 MySQL 并发控制
数据库·mysql·面试·并发·mvcc
小杜的生信筆記34 分钟前
生信技能技巧小知识,Linux多线程压缩/解压工具
linux·数据库·redis
Smoothcloud润云1 小时前
Google DeepMind 学习系列笔记(3):Design And Train Neural Networks
数据库·人工智能·笔记·深度学习·学习·数据分析·googlecloud
银发控、1 小时前
MySQL覆盖索引与索引下推
数据库·mysql·面试
金融小师妹1 小时前
基于NLP情绪分析与机器学习预测:避险情绪升温,黄金价格触及5200关键阈值
大数据·人工智能·机器学习·重构
long跨境电商1 小时前
跨境平台竞争下,卖家自养买家号测评如何安全高效操作?
大数据
DolphinDB智臾科技1 小时前
DolphinDB 与英方软件达成兼容互认,共筑高效数据新底座
数据库·时序数据库·dolphindb
ZJun_Ocean1 小时前
add_columns
数据库·sql
八角Z1 小时前
OpenClaw Windows 10 完整安装步骤细化说明
大数据·人工智能·windows·机器学习