mysql中获取一段时间日期

复制代码
SELECT
  date_add(date_sub('20230201', interval 1 day), INTERVAL (cast(help_topic_id AS signed INTEGER) + 1) day) as tttt
FROM mysql.help_topic
WHERE help_topic_id < DATEDIFF('20230201', date_sub('20230101', interval 1 day))
ORDER BY help_topic_id

其中mysql.help_topic是系统内置表,主要是为了获取从0开始的一个递增序列

解释:

date_sub(date, interval) 函数:

这个函数用于从给定日期中减去一个时间间隔。

在这个查询中,我们使用了 date_sub('20230201', interval 1 day),它减去了 '20230201' 这个日期的前一天,得到了一个新的日期。

cast(help_topic_id AS signed INTEGER) 函数:

这个函数用于将 help_topic_id 字段的值转换为有符号整数类型。

这是因为在后面的计算中需要对其进行加法操作,而加法操作要求操作数是数值类型。

INTERVAL (cast(help_topic_id AS signed INTEGER) + 1) day:

这个表达式用于计算一个时间间隔,根据 help_topic_id 的值来确定天数。

首先,cast(help_topic_id AS signed INTEGER) 将 help_topic_id 转换为有符号整数。

然后,对其进行加法操作 (cast(help_topic_id AS signed INTEGER) + 1),加 1 表示在原来的日期上增加一天。

最后,使用 INTERVAL 关键字将结果封装为一个时间间隔。

date_add(date, interval) 函数:

这个函数用于将给定日期加上一个时间间隔。

在这个查询中,我们使用了 date_add(date_sub('20230201', interval 1 day), INTERVAL (cast(help_topic_id AS signed INTEGER) + 1) day),它将前一天的日期(由 date_sub 计算得到)加上一个时间间隔(由上面的表达式计算得到),得到了一个新的日期。

FROM mysql.help_topic:

这部分指定了查询的数据源,即从 mysql.help_topic 表中获取数据。

mysql.help_topic 是 MySQL 数据库的内部表,用于存储关于帮助主题的信息。

WHERE help_topic_id < DATEDIFF('20230201', date_sub('20230101', interval 1 day)):

这个条件用于筛选满足特定条件的记录。

help_topic_id 必须小于 '20230201' 这个日期与前一天的日期之间的天数差值(由 DATEDIFF 计算得到)。

ORDER BY help_topic_id:

这个子句指定了结果集的排序方式,按照 help_topic_id 进行升序排序。

相关推荐
Re.不晚7 小时前
MySQL进阶之战——索引、事务与锁、高可用架构的三重奏
数据库·mysql·架构
chian-ocean10 小时前
CANN 生态进阶:利用 `profiling-tools` 优化模型性能
数据库·mysql
那个村的李富贵11 小时前
解锁CANN仓库核心能力:50行代码搭建国产化AIGC图片风格迁移神器
mysql·信息可视化·aigc·cann
斯普信专业组14 小时前
构建基于MCP的MySQL智能运维平台:从开源服务端到交互式AI助手
运维·mysql·开源·mcp
Exquisite.15 小时前
Mysql
数据库·mysql
·云扬·1 天前
MySQL Binlog落盘机制深度解析:性能与安全性的平衡艺术
android·mysql·adb
霖霖总总1 天前
[小技巧64]深入解析 MySQL InnoDB 的 Checkpoint 机制:原理、类型与调优
数据库·mysql
それども1 天前
分库分表的事务问题 - 怎么实现事务
java·数据库·mysql
·云扬·1 天前
MySQL Binlog 配置指南与核心作用解析
数据库·mysql·adb
天空属于哈夫克31 天前
Java 版:利用外部群 API 实现自动“技术开课”倒计时提醒
数据库·python·mysql