Clickhouse获取本周的最后一天、本月的最后一天
admin
2024-03-27 10:12:33
0

Clickhouse获取本周的最后一天、本月的最后一天

文章目录

  • Clickhouse获取本周的最后一天、本月的最后一天
    • 获取本周的最后一天
    • 本月的最后一天

Clickhouse官网日期函数:

https://clickhouse.com/docs/zh/sql-reference/functions/date-time-functions/#to-unix-timestamp

获取本周的最后一天

在官网给出的日期函数中,给出了计算指定日期所在周的第一天(周一):

toMonday()

将Date或DateTime向前取整到本周的星期一。 返回Date类型。

比如当前日期:

select toMonday(toDate('2022-12-08'));┌─toMonday(toDate('2022-12-08'))─┐
│                     2022-12-05 │
└────────────────────────────────┘

返回指定日期所在周的周一的日期

获取到指定日期所在周的最后一天的日期(周日)

date_add(DAY, 7-toDayOfWeek(toDate('2022-12-08')), toDate('2022-12-08'))┌─plus(toDate('2022-12-08'), toIntervalDay(minus(7, toDayOfWeek(toDate('2022-12-08')))))─┐
│                                                                             2022-12-11 │
└────────────────────────────────────────────────────────────────────────────────────────┘

核心思想就是利用toDayOfWeek方法计算出指定所在周的第几天,然后算出到周日的差值,再用date_add方法加上这个差值,就是当前当前日期所在周的周日的日期。

本月的最后一天

在官网给出的日期函数中,给出了计算指定日期所在月的第一天:

toStartOfMonth()

将Date或DateTime向前取整到本月的第一天。 返回Date类型。

比如当前日期:

select toStartOfMonth(toDate('2022-12-08'));┌─toStartOfMonth(toDate('2022-12-08'))─┐
│                           2022-12-01 │
└──────────────────────────────────────┘

那么如何获取到本月的最后一天呢?

select date_sub(DAY, 1, toStartOfMonth(date_add(MONTH, 1, toDate('2022-12-08'))))┌─minus(toStartOfMonth(plus(toDate('2022-12-08'), toIntervalMonth(1))), toIntervalDay(1))─┐
│                                                                              2022-12-31 │
└─────────────────────────────────────────────────────────────────────────────────────────┘

核心思想就是,先利用date_add方法计算出当前日期的下一个月所在的日期,然后利用toStartOfMonth方法算出下个月的月初,再利用date_sub方法将下个月月初的日期-1,就得到本月的最后一天所在的日期了。

注意,这里,如果下一个月的日期不存在,比如date_add(MONTH, 1, toDate('2022-10-31'));,11月不存在31号,只会得到2022-11-30:

select date_add(MONTH, 1, toDate('2022-10-31'));┌─plus(toDate('2022-10-31'), toIntervalMonth(1))─┐
│                                     2022-11-30 │
└────────────────────────────────────────────────┘

相关内容

热门资讯

北方华创,巨额商誉压力突然高悬... 文丨詹詹编辑丨百进来源丨新商悟(本文约为 1300字)当国内半导体设备龙头北方华创交出一份“营收创历...
长城华西银行原女掌门已回老东家... 湘财Plus注意到,四川银行入主长城华西银行后,该行核心管理人员调整基本落定,法定代表人已正式变更为...
立案,跌停!这家“童年记忆”,... 沉浮多年,方向何在?最近被立案的上市公司,着实有些多,就在上周末,又有一家上市公司及原董事长被立案调...
加码生态环境监测!生态环境部:... 本文来源:时代周报 作者:李杭4月27日,生态环境部举行4月例行新闻发布会。 生态环境部4月例行新...
东方甄选主播“离职潮”持续发酵... 红星资本局4月27日消息,东方甄选(01797.HK)主播“离职潮”事件仍在发酵。在社交平台上,有部...
SpaceX万亿IPO前夜:马... 从20亿美元收购,到万亿IPO前的最后叙事。2026年4月23日深夜,特斯拉向SEC提交了一份季报文...
前董事长陆宏达“闪电辞职”牵扯... 紧急澄清前董事长性侵指控后,智度股份仍难挡股价大跌。4月27日,智度股份早盘一度重挫逾9%,逼近6....
高盛:一场全球性化工危机正在爆... 霍尔木兹海峡通行受阻,正在引发一场史无前例的全球化工供应冲击。高盛最新报告表示,基础化工品价格近几周...
这笔400亿,谷歌买的不是友谊... 4月25日,Anthropic宣布谷歌将向其投资最高400亿美元——先期注入100亿美元现金,估值3...
粪坑,爬出来了 粪坑,爬出来了... 图:Simon Bailly 读者说:“有人发现吗?2019年蚂蚁的大热基金鹏华快回本了,当年最高回...