vertica截取函数-split_part

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vertica截取函数-split_part相关的知识,希望对你有一定的参考价值。

最近工作中遇到一个问题:vertica数据库,开发在入时间数据时格式为CST时间格式,导致查看数据时非常不方便。想了很久,终于想到了一个临时解决方案。
vertica的时间转换函数均不支持转换(至少todate,datetimestamp不可以,^^)。
数据库中时间格式如下
技术分享图片

开始发现date函数可以将该数据转换成yyyy-mm-dd,没有时分秒。
技术分享图片

此时想到另外一种想法,就是拼接,原来时间函数中时分秒格式没有问题,date可以转换成年月日,两个数据进行拼接,岂不美哉!

首先获取时分秒:
使用split_part函数,类似mysql中的substring函数。根据指定分隔符(观察数据发现此处使用空格为分隔符比较合适),获取数据。
select createtime,date(createtime),split_part(createtime,‘ ‘,4) from table ;
技术分享图片

接下来将上图中的最后两个字段拼接起来,看起来就是正常的时间格式了。
select createtime,date(createtime),split_part(createtime,‘‘,4),
to_char(date(createtime),‘yyyy-mm-dd‘||‘ ‘||split_part(createtime,‘ ‘,4)) from table;
技术分享图片

至此,比较笨拙的转换完成了,望有更好方法的大侠们积极告知。

以上是关于vertica截取函数-split_part的主要内容,如果未能解决你的问题,请参考以下文章

关于如何在vertica上使用MySQL的group_concat()函数

在 Vertica 中创建 percentile_cont 作为聚合函数

vertica提取json字段值

Vertica的这些事(十六)——Vertica如何建表

vertica,greenplum 安装

Vertica7 Native Connection Load Balance