ClickHouse:如何将toYYYYMMDD之后的整数转换回DateTime



在ClickHouse中,toYYYYMMDD返回按位置设置的年/月/日的整数。

SELECT toYYYYMMDD(now())
┌─toYYYYMMDD(now())─┐
│          20211112 │
└───────────────────┘

如何将此整数转换回Date类型?

您可以尝试parseDateTimeBestEffort:https://clickhouse.com/docs/en/sql-reference/functions/type-conversion-functions/#parsedatetimebesteffort

SELECT parseDateTimeBestEffort(toString(20211112))

┌─parseDateTimeBestEffort(toString(20211112))─┐
│                         2021-11-12 00:00:00 │
└─────────────────────────────────────────────┘

从21.12 开始

select toDate('20211111')
┌─toDate('20211111')─┐
│         2021-11-11 │
└────────────────────┘

数字是不可能的,因为数字已经被toDate(number_of_dates_from_1970)使用了

SELECT toDate(18942)
┌─toDate(18942)─┐
│    2021-11-11 │
└───────────────┘

没有函数fromYYYYMMDD,因为以前没有人问过。

最新更新