oracle的trunc函数改为hive的函数
创始人
2024-04-23 15:41:47
0

trunc函数可以截取oracle的日期

select trunc(sysdate,'yyyy') from dual;--返回当年第一天
select trunc(sysdate,'mm') from dual; --返回当月第一天
select trunc(sysdate,'dd') from dual;--返回当前年月日
select trunc(sysdate,'d') from dual; --返回当前星期的第一天(星期日) 
select trunc(sysdate,'hh') from dual;--返回当前日期截取到小时,分秒补0
select trunc(sysdate,'mi') from dual;--返回当前日期截取到分,秒补0

select trunc(sysdate,'Q') from dual; --返回当前季度的第一天
select trunc(sysdate,'month') from dual; --返回当前月份的第一天
select trunc(sysdate,'day') from dual; --返回当前天的第一天

 hive 本身也支持trunc时间但是有点垃圾

select 'YEAR' ,trunc('2022-12-13 14:15:16','YEAR') union all 
select 'Q' ,trunc('2022-12-13 14:15:16','Q') union all 
select 'MM' ,trunc('2022-12-13 14:15:16','MM')

注意返回值不保留时分秒格式 因为默认都是00:00:00

 

 但是hive不会这么垃圾,也可以如下函数来达成目的 而且更加的明了

SELECT 'current_timestamp',cast(current_timestamp AS string )
UNION ALL 
select 'floor_year',date_format(floor_year(current_timestamp),'yyyy-MM-dd HH:mm:ss')
UNION ALL 
select 'floor_quarter',date_format(floor_quarter(current_timestamp),'yyyy-MM-dd HH:mm:ss')
UNION ALL 
select 'floor_month',date_format(floor_month(current_timestamp),'yyyy-MM-dd HH:mm:ss')
UNION ALL 
select 'floor_day',date_format(floor_day(current_timestamp),'yyyy-MM-dd HH:mm:ss')
UNION ALL 
select 'floor_hour',date_format(floor_hour(current_timestamp),'yyyy-MM-dd HH:mm:ss')
UNION ALL 
select 'floor_minute',date_format(floor_minute(current_timestamp),'yyyy-MM-dd HH:mm:ss')

 注意floor_xx(timestamp) 只能接受timestamp,返回的是varchar

 如果你想使用字符串 可以通过 cast('2022-12-12' as timestamp) 然后再接floor函数 或者如下

select date_format(current_date,'yyyy-MM-dd HH:mm:ss'); --返回当前年月日

select  date_format(to_date(current_timestamp),'yyyy-MM-dd HH:mm:ss');--返回当前年月日

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
【PdgCntEditor】解... 一、问题背景 大部分的图书对应的PDF,目录中的页码并非PDF中直接索引的页码...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
修复 爱普生 EPSON L4... L4151 L4153 L4156 L4158 L4163 L4165 L4166 L4168 L4...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...