【问题标题】:ClickHouse: How to convert integer after toYYYYMMDD back to DateTime?ClickHouse:如何将toYYYYMMDD之后的整数转换回DateTime?
【发布时间】:2021-12-24 21:50:43
【问题描述】:

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

SELECT toYYYYMMDD(now())

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

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

【问题讨论】:

    标签: clickhouse


    【解决方案1】:

    你可以试试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 │
    └─────────────────────────────────────────────┘
    

    【讨论】:

      【解决方案2】:

      从 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,因为之前没有人问过。

      【讨论】:

        猜你喜欢
        • 2020-01-01
        • 2019-02-20
        • 2023-03-17
        • 1970-01-01
        • 2018-11-26
        • 1970-01-01
        • 1970-01-01
        • 2020-09-11
        相关资源
        最近更新 更多