ClickHouse:如何将 toYYYYMMDD 之后的整数转换回 DateTime?
ClickHouse: How to convert integer after toYYYYMMDD back to DateTime?
在 ClickHouse toYYYYMMDD
returns 位置设置了 year/month/day 的整数。
SELECT toYYYYMMDD(now())
┌─toYYYYMMDD(now())─┐
│ 20211112 │
└───────────────────┘
如何将这个整数转换回日期类型?
你可以试试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
因为之前没有人问过
在 ClickHouse toYYYYMMDD
returns 位置设置了 year/month/day 的整数。
SELECT toYYYYMMDD(now())
┌─toYYYYMMDD(now())─┐
│ 20211112 │
└───────────────────┘
如何将这个整数转换回日期类型?
你可以试试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
因为之前没有人问过