clickhouse复杂时间格式的转换方式

 更新时间:2023年12月21日 16:13:38   作者:阿爵  
这篇文章主要介绍了clickhouse复杂时间格式的转换方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

clickhouse复杂时间格式转换

1.如果只用toDateTime

你需要拼接成一个完全按照YYYY-MM hh:mm:ss格式的字符串给它

否则,它会当你是一个从1970年偏移的毫秒去转换

SELECT 20191231235959 as expire_date, toDateTime(20191231235959), 
concat(toString(floor(20191231235959/10000000000)), '-', 
toString(floor((20191231235959%10000000000)/100000000)), '-', 
toString(floor((20191231235959%100000000)/1000000)), ' ', 
toString(floor((20191231235959%1000000)/10000)),  ':', 
toString(floor((20191231235959%10000)/100)),  ':', 
toString(floor((20191231235959%10000)/100))) as str, toDateTime(str);

2.也可以这样拼接

toDateTime(concat(substring(toString(watch_end_time), 1, 4), '-', 
substring(toString(watch_end_time), 5, 2), 
'-', substring(toString(watch_end_time), 7, 2), ' 
', substring(toString(watch_end_time), 9, 2),
 ':', substring(toString(watch_end_time), 11, 
2), ':', substring(toString(watch_end_time), 13, 2))) as wet

3.但你可以使用一个更强大的函数

parseDateTimeBestEffort(toString(20191201000407)) as wet

结果:

wet
2019-12-01 00:04:07

附相关文档:

  • parseDateTimeBestEffort

将数字类型参数解析为Date或DateTime类型。

与toDate和toDateTime不同,parseDateTimeBestEffort可以进行更复杂的日期格式。

  • parseDateTimeBestEffortOrNull

与parseDateTimeBestEffort相同,但它遇到无法处理的日期格式时返回null。

  • parseDateTimeBestEffortOrZero

与parseDateTimeBestEffort相同,但它遇到无法处理的日期格式时返回零Date或零DateTime。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 详解DBeaver连接MySQL8以上版本以及解决可能遇到的问题

    详解DBeaver连接MySQL8以上版本以及解决可能遇到的问题

    这篇文章主要介绍了DBeaver连接MySQL8以上版本以及解决可能遇到的问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • MySQL [Warning] TIMESTAMP with implicit DEFAULT value is deprecated(报错信息解决)

    MySQL [Warning] TIMESTAMP with implicit&

    本文介绍了MySQL中常见的报错信息及其解决方法,主要包括TIMESTAMP with implicit DEFAULT value is deprecated、ERROR_FOR_DIVISION_BY_ZERO和NO_ZERO_DATE/NO_ZERO_IN_DATE等报错信息,以及对应的配置文件设置和sql_mode修改方法,感兴趣的朋友一起看看吧
    2025-02-02
  • MySQL数据库中表的操作详解

    MySQL数据库中表的操作详解

    这篇文章主要为大家详细介绍了MySQL数据库中表常用的一些操作方法,文中的示例代码讲解详细, 对我们学习MySQL有一定帮助,需要的可以参考一下
    2022-08-08
  • MySQL表自增id溢出的故障原因和解决方法

    MySQL表自增id溢出的故障原因和解决方法

    MySQL 表的自增 ID 溢出问题通常发生在使用 INT 或 BIGINT 类型的自增字段时,如果数据量极大,达到自增字段的最大值时,就会导致溢出,不同的数据库类型有不同的最大值,本文给大家介绍了MySQL表自增id溢出的故障原因和解决方法,需要的朋友可以参考下
    2024-12-12
  • Mysql 5.7.17忘记密码怎么办

    Mysql 5.7.17忘记密码怎么办

    这篇文章主要介绍了Mysql 5.7.17忘记密码的解决方法,需要的朋友可以参考下
    2017-03-03
  • mysql修改sql_mode报错的解决

    mysql修改sql_mode报错的解决

    今天在Navicat中运行sql语句创建数据表出现了错误Err 1067。本文主要介绍了mysql修改sql_mode报错的解决,感兴趣的可以了解一下
    2021-09-09
  • MySQL数据库的实时备份知识点详解

    MySQL数据库的实时备份知识点详解

    本篇文章给大家分享了关于MySQL数据库的实时备份知识点内容,有需要的朋友们可以参考下。
    2018-08-08
  • Mysql服务器的启动与停止(一)

    Mysql服务器的启动与停止(一)

    Mysql服务器的启动与停止(一)...
    2006-11-11
  • 关于pt-archiver和自增主键的那些事

    关于pt-archiver和自增主键的那些事

    mysql是我们经常会用到的一个数据库,mysql数据库中有一个主键生成规则,就是自增,这篇文章主要给大家介绍了关于pt-archiver和自增主键的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-04-04
  • MySQL 8.0升级中的字符集陷阱与解决方案

    MySQL 8.0升级中的字符集陷阱与解决方案

    在企业数字化转型的浪潮中,数据库系统的升级换代是必经之路,MySQL 8.0作为重要的里程碑版本,带来了诸多性能提升和新特性,但同时也埋下了一些技术地雷:字符集排序规则的变化,本文将基于一个真实案例,深度剖析MySQL 8.0字符集排序规则冲突问题的根本原因
    2026-01-01

最新评论