MaxCompute SQL使用小技巧之时间日期处理

本文涉及的产品
云原生大数据计算服务MaxCompute,500CU*H 100GB 3个月
云原生大数据计算服务 MaxCompute,5000CU*H 100GB 3个月
简介: 业务需求分析中经常会对时间日期进行处理,MaxComputer中也有很多关于日期的处理函数,文章就是对这些内置函数相互嵌套使用达到分析要求的分析

我们分析需求时经常会遇到如:最近一周、最近一个月、月初、月末、本季度...等等的时间修饰词,这类修饰词就构成了派生指标。使用Maxcomputer的童鞋都知道,其内置函数和Hive还是有些区别的,接下来我们就看看如何使用Maxcomputer内置日期函数。

  • 时间戳与日期的相互转换
select from_unixtime(1629785626);--2021-08-24 14:13:46select unix_timestamp(datetime'2021-08-24 14:13:46');--1629785626
  • yyyymmdd与yyyy-mm-dd之间相互转换
select to_char(to_date('20210824','yyyymmdd'),'yyyy-mm-dd');--2021-08-24select to_char(to_date('2021-08-24','yyyy-mm-dd'),'yyyymmdd');--20210824
  • 获取年份
selectyear('2021-08-24 14:13:46');--2021
  • 获取月份
select datepart(datetime'2021-08-24 14:13:46','mm');--8select month('2021-08-24 14:13:46');--8
  • 获取日
select datepart(datetime'2021-08-24 14:13:46','dd');--24select day('2021-08-24 14:13:46');--24
  • 获取小时
select datepart(datetime'2021-08-24 14:13:46','hh');--14select hour('2021-08-24 14:13:46');--14
  • 获取分钟
select datepart(datetime'2021-08-24 14:13:46','mi');--13select minute('2021-08-24 14:13:46');--13
  • 获取秒
select datepart(datetime'2021-08-24 14:13:46','ss');--46select second('2021-08-24 14:13:46');--46
  • 本周第几天
select weekday(to_date('2021-08-24','yyyy-mm-dd'));--1 周一返回的是0,周日为6
  • 本月第几天
select dayofmonth('2021-08-24');--24
  • 本年第几周
select weekofyear(to_date('2021-08-24','yyyy-mm-dd'));--34
  • 本年第几天
select datediff(to_date('2021-08-24','yyyy-mm-dd'),datetrunc(to_date('2021-08-24','yyyy-mm-dd'),'yyyy'));--235
  • 本年第几季度
select quarter('2021-08-24');--3
  • 本周第一天
select date_add(next_day('2021-08-24','MO'),-7);--2021-08-23
  • 本周最后一天
select date_add(next_day('2021-08-24','MO'),-1);--2021-08-29
  • 最近一周
select date_add('2021-08-24',-7);--2021-08-17
  • 已知日期返回周几,2018-01-01刚好是周一
select case pmod(datediff('2021-08-24','2018-01-01'),7)            when 0 then '周一'            when 1 then '周二'            when 2 then '周三'            when 3 then '周四'            when 4 then '周五'            when 5 then '周六'            when 6 then '周日'        end ;--周二
  • 上周一
select date_add(next_day('2021-08-24','MO'),-14);--2021-08-16
  • 上周末
select date_add(next_day('2021-08-24','MO'),-8);--2021-08-22
  • 本月第一天
select datetrunc(to_date('2021-08-24','yyyy-mm-dd'),'mm');--2021-08-01 00:00:00select date_sub('2021-08-24',dayofmonth('2021-08-24')-1);--2021-08-01
  • 本月最后一天
select lastday(to_date('2021-08-24','yyyy-mm-dd'));--2021-08-31select last_day('2021-08-24');--2021-08-31
  • 上个月月末
select dateadd(to_date(last_day('2021-08-24'),'yyyy-mm-dd'),-1,'mm');--2021-07-31 00:00:00
  • 上个月初
select add_months(date_sub('2021-08-24',dayofmonth('2021-08-24')-1),-1);--2021-07-01
  • 上个月同期
select add_months(to_date('2021-08-24','yyyy-mm-dd'),-1);--2021-07-24
  • 本季度第一天
select dateadd(dateadd(datetrunc(to_date('2021-08-24','yyyy-mm-dd'),'year'),quarter(to_date('2021-08-24','yyyy-mm-dd'))*3,'month'),-1,'mm');--2021-09-01 00:00:00
  • 本季度最后一天
select dateadd(dateadd(datetrunc(to_date('2021-08-24','yyyy-mm-dd'),'year'),quarter(to_date('2021-08-24','yyyy-mm-dd'))*3,'month'),-1,'dd');--2021-09-30 00:00:00
  • 上个季度第一天
select dateadd(dateadd(datetrunc(to_date('2021-08-24','yyyy-mm-dd'),'year'),(quarter(to_date('2021-08-24','yyyy-mm-dd'))-1)*3,'month'),-1,'mm');--2021-06-01 00:00:00
  • 上个季度末一天
select dateadd(dateadd(datetrunc(to_date('2021-08-24','yyyy-mm-dd'),'year'),(quarter(to_date('2021-08-24','yyyy-mm-dd'))-1)*3,'month'),-1,'dd');--2021-06-30 00:00:00
  • 本年第一天
select datetrunc(to_date('2021-08-24','yyyy-mm-dd'),'year');--2021-01-01 00:00:00
  • 本年最后一天
select date_add(add_months(datetrunc(to_date('2021-08-24','yyyy-mm-dd'),'year'),12),-1);--2021-12-31
  • 去年同期
select add_months(to_date('2021-08-24','yyyy-mm-dd'),-12);--2020-08-24

关于日期之间的转换有很多中方式,不限于以上方式,希望能帮助到小伙伴

拜了个拜

相关实践学习
基于MaxCompute的热门话题分析
本实验围绕社交用户发布的文章做了详尽的分析,通过分析能得到用户群体年龄分布,性别分布,地理位置分布,以及热门话题的热度。
SaaS 模式云数据仓库必修课
本课程由阿里云开发者社区和阿里云大数据团队共同出品,是SaaS模式云原生数据仓库领导者MaxCompute核心课程。本课程由阿里云资深产品和技术专家们从概念到方法,从场景到实践,体系化的将阿里巴巴飞天大数据平台10多年的经过验证的方法与实践深入浅出的讲给开发者们。帮助大数据开发者快速了解并掌握SaaS模式的云原生的数据仓库,助力开发者学习了解先进的技术栈,并能在实际业务中敏捷的进行大数据分析,赋能企业业务。 通过本课程可以了解SaaS模式云原生数据仓库领导者MaxCompute核心功能及典型适用场景,可应用MaxCompute实现数仓搭建,快速进行大数据分析。适合大数据工程师、大数据分析师 大量数据需要处理、存储和管理,需要搭建数据仓库?学它! 没有足够人员和经验来运维大数据平台,不想自建IDC买机器,需要免运维的大数据平台?会SQL就等于会大数据?学它! 想知道大数据用得对不对,想用更少的钱得到持续演进的数仓能力?获得极致弹性的计算资源和更好的性能,以及持续保护数据安全的生产环境?学它! 想要获得灵活的分析能力,快速洞察数据规律特征?想要兼得数据湖的灵活性与数据仓库的成长性?学它! 出品人:阿里云大数据产品及研发团队专家 产品 MaxCompute 官网 https://www.aliyun.com/product/odps 
目录
相关文章
|
1天前
|
SQL 分布式计算 DataWorks
DataWorks产品使用合集之未保存的ODPS SQL语句该如何找回
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
|
26天前
|
SQL 分布式计算 MaxCompute
SQL开发问题之对于ODPS中的UNION操作,执行计划的问题如何解决
SQL开发问题之对于ODPS中的UNION操作,执行计划的问题如何解决
|
26天前
|
分布式计算 MaxCompute 计算机视觉
ODPS问题之odps.sql.mapper.split.size属性有什么作用,以及如何根据场景调整它
ODPS问题之odps.sql.mapper.split.size属性有什么作用,以及如何根据场景调整它
|
6天前
|
大数据
大数据 - ODS&DWD&DIM-SQL分享
大数据 - ODS&DWD&DIM-SQL分享
12 0
|
1月前
|
SQL 分布式计算 资源调度
MaxCompute操作报错合集之执行SQL Union All操作时,数据类型产生报错,该怎么解决
MaxCompute是阿里云提供的大规模离线数据处理服务,用于大数据分析、挖掘和报表生成等场景。在使用MaxCompute进行数据处理时,可能会遇到各种操作报错。以下是一些常见的MaxCompute操作报错及其可能的原因与解决措施的合集。
|
1月前
|
SQL 分布式计算 大数据
MaxCompute操作报错合集之执行多条SQL语句时,使用同一个实例来运行,遇到报错,该如何解决
MaxCompute是阿里云提供的大规模离线数据处理服务,用于大数据分析、挖掘和报表生成等场景。在使用MaxCompute进行数据处理时,可能会遇到各种操作报错。以下是一些常见的MaxCompute操作报错及其可能的原因与解决措施的合集。
|
27天前
|
监控 前端开发 SQL
ODPS SQL问题之在何种情况下建议使用Distributed Map Join
ODPS SQL问题之在何种情况下建议使用Distributed Map Join
|
27天前
|
SQL 分布式计算 MaxCompute
ODPS SQL问题之为什么使用odps.sql.groupby.skewindata = true优化后,逻辑执行计划会发生改变如何解决
ODPS SQL问题之为什么使用odps.sql.groupby.skewindata = true优化后,逻辑执行计划会发生改变如何解决
|
27天前
|
SQL 分布式计算 监控
ODPS SQL问题之在ODPS SQL中,Shuffle的概念是什么
ODPS SQL问题之在ODPS SQL中,Shuffle的概念是什么
|
27天前
|
存储 分布式计算 资源调度
ODPS SQL问题之ODPS逻辑层包含哪些角色,它们各自的功能是什么
ODPS SQL 问题之ODPS逻辑层包含哪些角色,它们各自的功能是什么