码迷,mamicode.com
首页 > 其他好文 > 详细

vertica截取函数-split_part

时间:2018-11-07 11:30:59      阅读:488      评论:0      收藏:0      [点我收藏+]

标签:个数   开始   数据库   截取   ESS   方法   工作   分享   完成   

最近工作中遇到一个问题: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

标签:个数   开始   数据库   截取   ESS   方法   工作   分享   完成   

原文地址:http://blog.51cto.com/yuan00/2313788

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!