Spark SQL计算上一季度的第一天 [英] Computing First Day of Previous Quarter in Spark SQL

查看:37
本文介绍了Spark SQL计算上一季度的第一天的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

如何使用 SQL API 在 Spark-SQL 查询中获得与任何给定日期相关的最后季度的第一天?一些必需的样本如下:

How do I derive the first day of the last quarter pertaining to any given date in Spark-SQL query using the SQL API ? Few required samples are as below:

input_date | start_date
------------------------
2020-01-21 | 2019-10-01
2020-02-06 | 2019-10-01
2020-04-15 | 2020-01-01
2020-07-10 | 2020-04-01
2020-10-20 | 2020-07-01
2021-02-04 | 2020-10-01

宿舍通常是:

1 | Jan - Mar
2 | Apr - Jun
3 | Jul - Sep
4 | Oct - Dec

注意:我使用的是 Spark SQL v2.4.

Note:I am using Spark SQL v2.4.

感谢任何帮助.谢谢.

推荐答案

使用 date_trunc 和 3 个月的否定.

Use the date_trunc with the negation of 3 months.

df.withColumn("start_date", to_date(date_trunc("quarter", expr("input_date - interval 3 months"))))
  .show()

+----------+----------+
|input_date|start_date|
+----------+----------+
|2020-01-21|2019-10-01|
|2020-02-06|2019-10-01|
|2020-04-15|2020-01-01|
|2020-07-10|2020-04-01|
|2020-10-20|2020-07-01|
|2021-02-04|2020-10-01|
+----------+----------+

这篇关于Spark SQL计算上一季度的第一天的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆